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(54) A printer having a memory for storing a printer profile parameter 

(57) A host system for controlling a print head of an ■ ^ 

image printing device having at least one print head. 
The system includes the steps of obtaining profile info r- 
mation of t h<> '^^^ print hft^^i s toring the profi le 
parameters in a non-volatile memory, and outputting, 
upon request, t he profile information to a host comput er 
connected to the image printing device, wherein the 
host conputer utilizes the print head profile information 
to produce compensation parameters which compen- 
sate print information to be sent from the host cornputer 
to the print head for printing. 
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Description 



[0001] The present invention relates to printing devices wliich print images on a print medium, in particular, the 
present invention is a printer which includes a memory which stores a printer profile parameter which is utilized by the 

5 host computer to control the printer based on the printer profile parameter. 

[0002] Conventional ink jet printers have either a single print head arrangement or multiple print head arrangement 
for printing. In the latter case, printing speed of image data is increased using the multiple print head design. For exam- 
ple. U.S. Patent No, 4,272,771 discloses an example of a method which increases the print speed of serial image print- 
ing by using two print heads, one to print the left half of a printed line and the other to print the right half of a printed line. 

10 both halves being printed simultaneously. To achieve this result, left and right print head assemblies are supported by 
a common carriage mechanism. As a result, print speed is approximately doubled over that of a single print head 
device. 

[0003] In iDoth single print head printers and multiple print head printers, the print heads and ink cartridges which pro- 
vide the ink output from the print heads are both interchangeable and disposable. For example, a black cartridge may 
75 be exchanged for a cyan, magenta and yellow (CMY) cartridge and vice versa. Additionally, there are ink cartridges 
which provide different printing effects, such as a photo-style ink cartridge which provides photograph-like qualities an6 
pigment ink cartridges which provide different printing effects. 

[0004] Because print heads become clogged or partially dysfunctional over time, print heads are designed to be 
replaced. Depending on the cartridge and manufacturer, the ink cartridge and print head are combined so that the 

20 entire ink cartridge and print head can be replaced when the ink runs out 

[0005] While it is convenient to replace or to exchange ink cartridges and print heads of an ink jet printer, this conven- 
ience brings with it problems due to physical differences between inks and print heads. For example, because each ink 
and each manufactured print head may be from different manufacturing lots, the Inks and print heads may have different 
physical characteristics. These variations in physical characteristics in print heads alter print head alignment from one 

25 print head to the next. Similariy, variations in physical characteristics of ink will vary output image density. As a result of 
these variations, unwanted variations occur in the printed document 

[0006] As may be appreciated, this problem is compounded when using two or more print heads. For i^niple, rn the 
case that one print head is printing the left half of a print line in a document and the other print head is printing the right 
half of a print line in a document, if the two print heads are not aligned, the misalignment will be quite noticeable. In the 
30 case that the same color ink is being used by both print heads and the ink densities 6f both print heads do not match, 
the varied image densities will be quite noticeable in the printed document 

[0007] In view of the varied output from each print head, it is desirable to know a print head's alignment, ink density; 
as well as other print head characteristics which may affect printing so that these variations may be compensated for 
before printing. 

35 [0008] On the other hand, in the system of a host computer and a prirrter, if the information of the characteristics of 
the printing, which depends on the current status of the printer, is stored in the memory of the host computer, when the 
printer is separated from the host computer and connected to another computer, the new computer can not use the 
information stored in the former computer. 

[0009] Further, a corrventional printer does not remember the oorKlitton change of the printer after power-off. There- 
40 fore, for example, if the power of the printer has been off after the change to a new print head, the printer can not under- 
stand whether it should make a cleaning operation or not. 

[0010] An aspect of the invention provides printing control that overcomes the fore^ing disadvantages found in the 
prior art systems. 

[001 1 ] According to one aspect of the present invention, a non-volat'le.memory, such as an EEPROM, is provided in 
45 a prirrter The non-volatile memory (NVRAM) is capable of storing various profile parameters and measurements of the 
print head or print heads, including ink information. This information is in turn output to a host computer which utilizes 
this information to produce image information for printing. According to another aspect of the invention, a compensation 
parameter is stored back in the printer's NVRAM and Is used by the host computer to alter commands to the printer dur- 
ing a printing operation. By storing the parameter in the NVRAM, outputting the parameter to the host computer and 
50 allowing the host computer to calculate and compensate for print head variations, costs for the printer can be reduced. 
[0012] Moreover, by storing printer profile parameters and/or measurements in a NVRAM, it is possible for a host 
computer to check the status of the printer and to obtain information which may affect printing output. More importantly, 
if the printer is disconnected from host computer and connected to another host computer, the parameters and meas- 
urements are stored with the printer and therefore are readily available to the new host computer. As a result, the newly 
55 connected host computer can compensate for variations in the print heads arrd/or inks when sending data for each print 
job. 

[001 3] Thus, in accordance with one aspect, the present invention is a method for controlling a print head of an image 
printing device having at least one print he^. The method includes the steps of obtaining profile information of the at 
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least one print head, storing the profile parameters in a non-volatile RAM. outputting. upon request, the profile infbrnria- 
tion to a host computer connected to the Image printing device, wherein the host computer utilizes the print head profile 
Information to produce compensation parameters which compensate print information to be sent from the host compu- 
ter to the print head for printing. 

5 [0014] According to another aspect of the invention, a printer controller for a printer having at least one print device 
receives Image Information from an external device and controls a printer to form an image based on the image infor- 
mation. Further It has storing means for storing information concerning the printer, wherein a part of the storing means 
is non-volatile and stores the information which is used by the external device for producing the image information. 
[001 5] Further, according to another aspect of the invention, a printer controller for a printer having at least one print 

10 device receives image information from an external device, and controls a printer based on the image information. Fur- 
ther it has non-volatile memory means for storing information concerning a condition change of the printer which may 
occur during an off-line mode, and transmits the information to the external apparatus during a next on-line mode. 
[0016] Embodiments of the present Invention will now be described with reference to the accompanying drawings, in 
which: 

IS 

Figure 1 shows a perspective view of computing equipment used in connection with the printer of an embodiment 
of the present Invention. 

Figure 2 Is a front perspective view of the printer shown in Figure 1 . 
Rgure 3 Is a back perspective view of the printer shown In Figure 1 . 
20 Figure 4 Is a front, cut-away perspective view of the printer shown in Figure 1 . 
Figure 5 Is a back, cut-away perspective view of the printer shown in Figure 1 . 

Figures 6A and 6B show front and back views, respectively, of a cartrklge receptacle used in connection with an 
err^odiment of tiie present Invention. 

Rgure 7 shows an example of a disposable ink cartrkJge used with an embodiment of the present invention. 
25 Figures 7A and 7B shows views of an example of a second type of Ink cartridge that Is used with an embodiment 
of the present invention. 

Figure 8 shows a face-on vlisw of head configurations for print heads used with an emkxxiiment of the present 
invention. . 
Figure 9 shows dot configurations which are printed by the printer of an embodiment of the present invention.. . 
30 Figure 1 0 is a block diagram showing tiie hardware configuration of a host processor interfaced to the printer of an 
embodiment of the present invention. 

Figure 11 shows a functional block diagram of the host processor and printer shown in Figure 10. . . 

Figure 1 2 is a block diagram showing the internal configuration of the gate array shown in Figure 10. 
Figure 1 3 shows the memory architecture of the printer of an embodiment of the present Invention. 
35 Figure 14 shows an overall system flowchart detailing thie operation of the printer of an emtxxJiment of tiie present 
Invention. 

Figure 15 Is a flowchart showing printer response to user operation of the printer of an embodiment of tiie present 
invention. - 

Figure 16 is a fkywchart showing print control flow in accordance with an embodiment of the present invention. 
40 Figure 17 is a flowchart showing setting of scan parameters in an embodiment of the present invention. 
Figure 18 depicts a table showing command flow during a printing sequence. 

Figure 19 is a flow diagram which depk:ts a hard power-on sequence for the printer of an embodiment of the 
present Invention. 

Figure 20 is a flow diagram which depicts a soft povver-on sequence for the printer of an embodiment of the present 
45 Invention. 

Figure 21 Is a flow diagram which depicts a soft power-off sequence for the printer of an emtxxJimerrt of the present 
invention. 

Figure 22 shows cyclic handlers for various tasks including a Centronics interface task. 

Figure 23 ^ a flow diagram illustrating controller timer control according to a cyclic handler for controlling timer 
so operations. 

Figure 24 shows a detailed perspective view of the printer shown in Figure 1 , in which the printer has its ejection 
tray set up for operation. 

Figure 25 shows a detailed perspective view of the ejection tray of Figure 24. 

Rgure 25A is a clos~-up perspective view of an example of a t>eveled edg~ which is included on flaps used in the 
55 ejection tray of Figure 25. 

Figures 25B and 25C are views of the flap shown in Figure 25A used to explain the beveled edge. 
Figure 26 shows a detailed perspective view of connections of a flap on the ejection tray of Rgure 24. 
Figure 27 shows an alternate detailed perspective view of the ejection tray of Figure 24. 



3 



EP 0 917 096 A2 



Figure 28 shows a bottom view of the printer of Figure 1 . 

Figures 29A to 29D show the operation of the ejection tray of Figure 24. 

Figure 29E is a perspective view of a second embodiment of the paper ejection tray of an embodiment of the 
present invention. 

5 Figures 30A and 30B show the operation of a cartridge receptacle in the printer of an embodiment of the present - 

invention. 

Figures 31 A and 31 B show an ink cartridge installed in the cartridge receptacle of Figures 30A and 308. 
Rgure 32 shows the configuration of an ink cleaning mechanism used on the printer of Figure 1 . 
Figures 33A and 33B show ink cleaning of each print head installed in the printer of Figure 1. 
10 Figure 34 is a flowchart showing compensation of print head command data in a host processor. 

Figure 35 is a flowchart showing time t>ased cleaning performed in accordance with an embodiment of the present 
invention. 

Figure 36 is a flowchart showing the steps by which the printer of an embodiment of the present invention maintains 
an elapsed time schedule. 

15 Figures 37, 38, 39 and 40 are flowcharts showing the automatic cleaning sequence performed by the printer of an 
embodiment of the present invention. 

Rgure 41 is a flowchart showing ink cartridge head replacement in accordance with an emtKxJiment of the present 

invention. 

Figure 42 shows steps which are performed when paper is loaded in the printer of the present invention and an 
20 automatic cleaning sequence is initiated. 

Figure 43 is a timing diagram showing a cleaning schedule in accordance with an embodiment of the present inven- 
tion. 

Figure 43 A is a flowchart for describing control of printer nozzle driving times. 

Figure 438 is a diagram showing exploded views of tables for heat-up coefficients and tables for driving times 
25 stored in a printer 

Figure 43C is a flowchart for describing control of nozzle firing sequence and droplet size. 
Rgures 43D to 43F illustrate correlations between head usage and pi^int buffer usage for various printing condi- 
tions. 

Figure 43G illustrates nozzle heating sequences for various print conditions. 
30 Figures 43-1 A to 43-1 E show transfer of data from a host processor to a print buffer in a printer. 

Figures 43-2A to 43-2E show print data transfer in drawing a backward scan following a fonward scan. 
Figures 43-3A to 43-3F show transfer of print.data during forward scan of a single print head across a print medium. 
Figures 43-4A to 43-4F show print data transfer during a forward scan in an alternative embodiment of the inven- 
tion. 

35 Figures 43-5A to 43-5F show print data transfer during a backward scan after a forward scan has been performed. 

Figures 43-6A to 43:6F show print data transfer during a forward scan of a single print head. 

Figures 43-7A to 43-7L show print data transfer in a fbnward direction for a pair of print heads. 

Figure 44 A shows print data transfer in a forward direction for a pair of print heads. 

Figure 448 shows print data transfer in a backward direction for a pair of print heads. 
40 Figures 44C to 44M are flowcharts illustrating transfer of print data from a print data store in a host processor to a 

print buffer in a printer. 

Rgure 44N shows two block diagrams illustrating possible ^3plicatk>ns of a shift buffer technology within a printing 
system. 

Rgure 45 is a representational view for explaining the benefits of printout with different resolutions for each of dif- 
45 ferent heads. 

Figure 45A is a flow diagram showing process steps executed by a print driver in the host processor so as to control 
print resolution for each print head independently, and to command printout to be effectuated thereby. 
Rgure 46 shows a user interface associated with the printer of the present invention. 

Rgure 46A is a representational view for explaining the benef its of printing with different resolutions for a print head. 
50 Rgure 468 is a flow diagram showing process steps executed by a print driver in the host processor so as to control 
print resolution for a print head, and to command printout to be effectuated thereby. 

Rgure 47 is a flow diagram illustrating process steps performed by a printer for independent print resolution setting. 
Figure 48 is a flow diagram for describing a method of ink selection. 

Figure 49 illustrates a region used for determining whether a black target pixel lies within a differently-colored . 
55 region. 

Figure 49A is a flow diagram describing selection of CMYK tDlack ink or pigment-based black ink. 
Rgures 50A, SOB and 50C illustrate printing a region adjacent to a boundary between a black region and a differ- 
ently-colored region. 
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Figure 51 is a flow diagram for describing a method for printing a region adjacent to a boundary between a black 

region and a differently-colored region. 

Figure 52 is a flow diagram for describing a method for printing a region adjacent to a boundary between a black 
region and a differently-cofored region. 

Figures 53A. 53B and 53C illustrate a method for printing data based on print data of a region adjacent to a bound- 
ary between a black region and a differently-colored region. 
Figure 54 shows color processing according to one embodiment of the invention. 
Figures 54A and 54B show binarization of pixels in accordance with one embodiment of the invention. 

[0017] The detailed description of the embodiment is organized into sections, as follows: 

1.0 hffechanical 

1.1 Structure 

1.2 Functions 

1.2.1 Manual Cleaning 

1.2.2 Cartridge Replacement 

1.3 Ink Cartridge 

1.4 Print Head Structure 

1.5 Print Modes 

2.0 Electrical 

2.1 System Architecture * i 

2.2 System Function ' • 

2.3 Control Logic 

2.4 General operation 

3.0 Architecture of Printer Software 

3.1 Operating System > ^ 

3.2 Initialization 

3.3 Tasks 

3.4 Interrupt Handlers 

3.5 Cyclic Handlers 

3.6 Commands To And From The Host Processor 

3.6.1 Control Commands 

3.6.2 Setting Commands 

3.6.3 Maintenance Commands 

3.7 Commands To And From The Printer Engine 
4.0 Paper Ejection Tray 

4.1 First Embodiment 

4.2 Second Embodiment 

5.0 Ink Cleaning Mechanism 

6.0 Storing Printer Profile Parameters 

7.0 Scheduling Cleaning Off Print Heads 



7.1 Cleaning Schedule Process 

7.2 Automatic Cleaning Process 

7.3 Cleaning Of A Print Head 



EP 0 917 096 A2 



8.0 Setting And Modifying Print Head Driving Parameters 
9.0 Print Buffer Operation 

9.1 Single Print Buffer 
5 9.2 General Description Of Buffer Control 

10.0 Multi-Head Printing With Differing Resolutions 
11 .0 Selection of Alternative Inks 

10 11.1 Selection of CMYK Black or Pigment Black 

1 1 .2 Boundary Region Printing 

1 1.3 Printing With Different Inks at Different Resolutions 

1.0 lyiechanicai 

IS 

[0018] This section describes the mechanical layout and functionality of a printer which embodies the invention 
desaibed herein. 

1.1 Structure 

20 

[0019] Figure 1 is a view showing the outward appearance of computing equipment embodying the invention 
desaibed herein. Computing equipment 20 includes host processor 23. Host processor 23 comprises a personal com- 
puter (hereinafter "PC"), preferably an IBM PC-compatible computer having a wirxiowing environment such as Micro- 
soft® Wlndows95. Provided with computing equipment 20 are display screen 22 comprising a color monitor or the like, 
25 keyboard 26 for entering text data and user commands^ and pointing device 27. Pointing device 27 preferably comprises 
a mouse for pointing and for manipulating objects displayed on display screen 22. 

[0020] Computing equipment 20 Includes a computer-readable memory medium, such as fixed computer disk 25, and 
floppy disk interface 24. Floppy disk interface 24 provide a means whereby confuting equipment 20 can access infor- 
mation, such as data, application programs, etc.^ stored on floppy disks. A similar CD-ROM interface (not shewn) may 
30 be provided with computing equipment 20. through which computing equipment 20 can access information stored on 
CD-ROMs. 

[0021] Disk 25 stores, among other things, application programs by which host processor 23 generates files, manip- 
ulates and stores those files on disk 25, presents data in those files to an operator via display screen 22. and prints data 
in those files via printer 30. Disk 25 also stores an operating system which, as noted above, is preferably a windowing 
35 operating system such as Windows95. Device drivers are also stored in disk 25. At least one of the device drivers com- 
prises a printer driver which provides a software interface to firmware in printer 30. Data exchange between host proc- 
essor 23 and printer 30 is described in more detail below. 

[0022] In preferred embodiments of tiie invention, printer 30 is a multi-head serial printer. Accordingly, although the . 
emtxxliments described herein are not limited to use with such a printer, the embodiments will be described in the con-: 
40 text of a such a printer. 

[0023] In this regard. Figures 2 and 3 show close-up perspective front and back views, respectively, of printer 30. As 
shown in these figures, printer 30 includes housing 31, access door 32. automatic feeder 34, automatic feed adjuster 
36. manual feeder 37. manual feed adjuster 39, media eject port 40, ejection tray 41 . tray receptacle 42, indicator light 
43. power button 44, resume txitton 46, power supply 47, power cord 49, and parallel port connector 50. 

45 [0024] Housing 31 is approximately 498 mm in width by 271 mm in depth by 219 mm in height, and houses the inter- 
nal workings of printer 30, including the print engine described below which prints images onto recording media. 
Included on housing 31 is access door 32. Access door 32 is manually openat>le and closeabie so as to permit a user 
to access the internal workings of printer 30 and, in particular, to access print cartridges installed in printer 30. To tiiis 
end, printer 30 also includes a sensor (not shown) which senses when access door 32 has been opened and closed. 

so Once it is sensed that access door 32 has been opened, cartridge receptacles which reteasably hold the cartridges 
within printer 30 are moved to a position which corresponds to open access door 32. Details of this feature are provided 
below. 

[0025] Disposed on tiie top of access door 32 is a front panel comprising indicator light 43. power button 44, and 
resume button 46. Power txjtton 44 is a control by which a user can turn printer 30 on and off. Additional functions, how- 
55 ever, are also available through power button 44. For example, a test print function can be selected by holding down 
power button 44 until a speaker (not shown) in prirrter 30 emits a sound, such as one beep. In response to this test print 
function, printer 30 prints a test pattern. 

[0026] Resume button 46 provides corttrol by which an operator can resume printing after an error condition has 
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occurred. In addition, resume button 46 can be used to activate other functions. For example, a print head cleaning 
function can be activated by holding down resume button 46 until the speaker in printer 30 produces a beep. 
[0027] In this regard, printer 30 is able to provide a variety of consecutive beeping sounds. Each of these sounds indi- 
cates a different type of error, such as paper empty, paper jam. etc. 

5 [0028] Indicator light 43 is comprised of a single light pipe, a green light emitting diode (hereinafter "LED"), and an 
orange LED. Indicator light 43 provides a user with an indication of the operational state of printer 30. Specrfically, when 
Irxjicator light 43 is off. this indicates that printer 30 is powered off. When Indicator light 43 is Illuminated green (i.e.. the 
green LED is activated), this indicates that printer 30 is powered on and is ready for printing. When indicator light 43 is 
green and tDlinking. this indicates an opei^ational state of the printer, such as that the printer is currerrtly powering on. 

10 [0029] Indicator light 43 can also be illuminated orange by the orange LED. When indicator light 43 is illuminated 
orange, this indicates that a recoverable error, i.e., an operator call error, has occurred in printer 30. Recoverable errors 
comprise paper empty, paper jam, defective cartridge installed in printer 30. cartridge replacement in process, etc. It is 
possible to distinguish the type of recoverable error based on a number of beeps from printer 30's speaker. By counting 
these beeps when indicator LED is continuously orange, a user can determine which error has occurred and act 

15 accordingly. 

[0030] When indicator light 43 is orange and blinking, this indicates that a fatal error, i.e.. a service call en^or. has 
occurred in printer 30. It is possible to distinguish the type of fatal error that has occurred merely by counting how many 
times the orange light has blinked. 

[0031] As shown in Figures 2 and 3. automatic feeder 34 is also included on housing 31 of primer 30. Automatic 
20 feeder 34 defines a media feed portion of printer 30. That is. automatic feeder 34 stores recording media onto which 
printer 30 prints images. In this regard, printer 30 is able to print images on a variety of types of recording media. These 
types include, but are not limited to. plain paper, high resolution paper, transparencies, glossy paper, glossy film, back 
print film, fabric sheets. T-shirt transfers, bubble jet paper, greeting cards, brochure paper, banner paper, thick paper, 
etc. 

25 [0032] Automatlcf eeder 34 Is able to accommodate a recording media stack which is approximately 1 3 mm thick This 
means that automatic feeder 34 can hold. e.g.. approximately 130 sheets of paper having a density of 64 g/m^ or 
approximatdy 15 envelopes. During printing, individual sheets which are stacked within automatic feeder 34 are fed' 
from automatic feeder 34 through printer 30. Specifically, rollers (described below) in printer 30 draw individual media' 
from automatic feeder 34 into printer 30. These individual media are then fed in a "J" type path through the rollers to 

30 eject port 40 shown In Figure 2. 

[0033] Automatic feeder 34 includes automatic feed adjuster 36. Automatic feed adjuster 36 Is laterally movable to 
accommodate different media sizes within automatic feeder 34. Automatic feeder 34 also includes backing 55. which is 
exterKlible to support recording media held in automatic feeder 34. When not in use, backing 55 is stored within a slot 
in automatic feeder 34. as shown in Figure 2. An example of backing 55 extended is shown in Figure 24 below. 

35 [0034] Individual sheets also can be fed through printer 30 via manual feeder 37 shown in Figure 3. which also defines 
a media feed portion of printer 30. In preferred embodiments, manual feeder 37 can accommodate media having a den- 
sity of at least between 64 g/m^ and 550 g/m^, and having a thickness of 0.8 mm. Sheets fed through manual feeder 37 
are fed straight through the rollers in printer 30 to eject port 40. As was the case with automatic feeder 34, manual 
feeder 37 includes manual feed adjuster 39. By sliding manual feed adjuster 39 laterally, a user can vary the media 

40 which manual feeder 37 can accommodate. 

[0035] Using manual feeder 37 and automatic feeder 34; printer 30 can print images on media having a variety of 
different sizes. These sizes include, but are not limited to, letter, legal, A4, A3, A5. B4, B5, tabloid, #10 envelope. DL 
envelope, banner, wide banner, and LTR full bleed. Custom-sized recording media can also be used with printer 30. 
[0036] As noted above, media are fed through printer 30 and ejected from eject port 40 irrto ejection tray 41. As 

45 described in greater detail betow In section 4.0. ejection tray 41 includes spring-biased flaps which support media 
ejected from printer 30, and which move downwardly as nnore media are piled thereon. When not in use, ejection tray 
41 is stored within tray receptacle 42 of printer 30. as shown in Rgure 2. 

[0037] Power cord 49 connects printer 30 to an external AC power source. Power supply 47 is used to convert AC 
power from the external power source, and to supply the converted power to printer 30. Parallel port 50 connects printer 

50 30 to host processor 23. Parallel port 50 preferably comprises an IEEE-1284 bi-directional port, over which data and 
commands, such as those described betow in section 3.0. are transmitted between printer 30 and host processor 23. 
[0038] Figures 4 and 5 show back and front cut-away perspective views, respectively, of printer 30. As shown In Figure 
5. printer 30 includes rollers 60, noted above, for transporting media from either automatic feeder 34 or manual feeder 
37 through printer 30 to media eject port 40. Rollers 60 rotate in a counterclockwise direction during media transport. 

55 as indicated by arrow 60a shown In Figure 5. 

[0039] Line feed motor 61 controls tiie rotation of rollers 60. Line feed motor 61 comprises a 96-step. 2-2 phase pulse 
motor and is controlled in response to commands received from circuit board 62. Line feed motor 61 is driven by a motor 
driver having four level current control. 
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[0040] In preferred embodiments, line feed motor 61 is at>le to cause rollers 60 to rotate so that a recording medium 
IS fed through printer 30 at 120 mm/sec. In a primary mode of operation for printer 30, line feed resolution is 
(1/720)inches/pulse (2-2 phase), and in a 1440 dpi mode, line resolution is (1/144O)inches/0ulse (1*2 phase). Print 
modes are described in more detail below. 

5 [0041] As shown in Figure 4. printer 30 is a duat-cartridge printer which prints images using two print heads (i.e.. one 
head per cartridge). Specifically, these cartridges are held side-by-side by cartridge receptacles 64a and 64b such that 
respective print heads on the cartridges are offset horizontally from each other. Carriage motor 66. shown in Figure 5. 
controls the motion of cartridge receptacles 64a and 64b in response to commands received from circuit board 62. Spe- 
cifically, carriage motor 66 controls the motion of belt 67, which in turn controls the movement of cartridge receptacles 

10 64a and 64b along carnage 69. In this regard, carriage motor 66 provides for bi-directional motion of belt 67, and thus 
of cartridge receptacles 64a and 64b. By virtue of this feature, printer 30 is able to print images from both left to right 
and right to left. 

[0042] Carriage motor 66 comprises a 96-step. 2-2 phase pulse motor having a carriage resolution of 
(9y360)inches/pulse. Carriage motor 66 is driven by a motor driver having four level current control. When printer 30 is 

IS printing in a 360 dpi mode, carriage motor 66 is driven to cause cartridge receptacles 64a and 64b to move along car- 
riage 69 at a default speed of 459.32 mm/sec (10 Khz). In contrast, when printer 30 is printing in a 720 dpi mode, car- 
riage motor 66 is driven to cause cartridge receptacles 64a and 64b to move along carriage 69 at a default speed of 
229.66 mm/sec (5.0 Khz). Printing speed can also be decreased to 3.26 Khz, as described below In section 3.6.2. 
[0043] Figure 6A is a detailed perspective view of cartridge receptacle 64b from Figure 4. Both of cartridge recepta- 

20 cles 64a and 64b are identical in structure, except for the presence of an auto-alignment ("AA") sensor, which is only 
included on cartridge receptacle 64b. Accordingly, for the sake of brevity, only cartridge receptacle 64b is described in 
detail herein. 

[0044] Cartridge receptacle 64b is used to hold an ink cartridge (which includes a print head and can include one or 
more removable ink reservoirs for storing Ink) in printer 30. In this regard, Rgures 7A and 7B show the configuration of 
25 ink cartridge 300b which may be installed within cartridge receptacle 64b (see Figure 4). As shown in Figures 7A and 
78, ink cartridge 300b comprises print head 80, ink reservoirs 83. cartridge circuit contact 81 , and hole 90. At this point, 
it is noted that the present invention can also be used with ink cartridges that do not contain removable ink reservoirs, 
but instead store ail ink internally. 

[0O45] Ink reservoirs 83 are removable from ink cartridge 300b and store ink used by printer 30 to print images. Spe- 

30 crfically, ink reservoirs 83 are inserted within cartridge 300b and can be removed by pulling along the direction of arrow 
85, as shown in Figure 78. Reservoirs 83 can store color (e.g., cyan, magenta and yellow) ink and/or black ink. as 
described in more detail below. Print head 80 includes a plurality of nozzles (not shown) which eject ink from ink reser- 
voirs 83 during printing. Cartridge circuit contact 81 is used by printer 30 to trigger ink cartridge cleaning, as described 
below. Cartridge hole 90 mates to pin 93 on cartridge receptacle 84b so as to hold ink cartridge 300b in place. 

35 [0046] Returning to Figure 6A. cartridge receptacle 64b includes opening 79 at a bottom thereof. A print headi such 
as print head 80, of an installed cartridge protrudes through opening 79. By virtue of this configuration, the cartridge's . 
print head is able to contact a recording medium in printer 30. Cartridge receptacle 64b also includes lever 72 and cap- 
sule 73. As described in more detail in section 5.0 below, lever 72 pivots relative to ink reservoirs of an ink cartridge 
stored in cartridge receptacle 64b such that lever 72 extends over at least a portion of the ink reservoirs, and pivots 

40 away from the ink reservoirs so as to permit user access to tiie ink reservoirs. 

[0047] Capsule 73 holds the ink cartridge (including the print head and ink reservoirs) within cartridge receptacle 64b 
and is laterally movable within cartridge receptacle 64b in response to pivoting of lever 72. During this lateral motion, 
finger 282 on capsule 73 slidably engages sleeve 284 on stationary section 502. By virtue of this lateral motion, a car- 
tridge circuit contact, such as cartridge circuit contact 81 on ink cartridge 300b. engages and disengages a circuit con- 

45 tact on cartridge receptacle 64b, namely device drcuit contact 71 . This process is used to output a signal which prompts 
cleaning of a print head, and is described in more detail below. 

[0048] Figure 6B shows a back view of the construction of cartridge receptacle 64b. Specifically. Figure 6B shows the 
interconnection of capsule 73, lever 72. back piece 501 . and stationary section 502 (shown in two dotted/dashed lines). 
In this regard, lever 72 includes fingers 507 which connect to corresponding holes 504 in back piece 501. By virtue of 
so this arrangement, when lever 72 is pivoted downward in the direction of arow A^ shown in Figure 68, back piece 501 
moves upward in the direction of arrow also shown in Figure 68. Conversely, when lever 72 is pivoted upward in the 
direction of arrow Bf , back piece 501 moves downward in the direction of arrow 82. This upward and downward move- 
ment of t>ack piece 501 controls the lateral movement of capsule 73 described above. 

[0049] To this end, back piece 501 includes cam surface 509 which interacts with spring-loaded push rod 510 when 
55 the lever/k>ack piece assembly is installed in stationary section 502. Specifically, the lever/back piece assembly is con- 
nected to stationary section 502 via fingers 508 and corresponding holes 506. When connected in this manner, cam 
surface 509 of back piece 501 contacts spring-loaded push rod 510 on the back of capsule 73. This connection causes 
capsule 73 to move laterally when lever 72 is pivoted. 
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[0050] More specifically, because cam surface 509 includes angled side 51 1 and straight side 512. when cam surface 
509 moves upwards (i.e.. when lever 72 is pivoted toward capsule 73 in the direction of arrow A^, causing back piece 
501 and thus cam surface 509 to move upward in the direction of arrow A2), push rod 510 is pushed in the direction of 
arrow A4 by angled side 51 1 of cam surface 509. This motion causes capsule 73 to move in the direction of arrow A3 
5 shown in Figure 6B. 

[0051] Conversely, when cam surface moves downward (i.e.. when lever 72 is pivoted away from capsule 73 in the 
direction of arrow Bi, causing back piece 501 and thus cam surface 509 to move downward In the direction of arrow 
B2). push rod 510 no longer contacts angled side 51 1 . Instead, cam surface 509 moves such that push rod 510 corre- 
sponds to straight side 512. In this position, spring 513. which is disposed underneath capsule 7C and which biases 
10 capsule 73 relative to stationary section 502, moves capsule 73 in the direction of arrow B3 shown in Figure 6B. 

[0052] As shown in Figure 6B, lever 72 also includes flanges 287 which contact shoukJers 286 on the capsule/station- 
ary section assembly. As described in more detail below, this contact reduces the chances that lever 72 will engage a 
cartridge and/or ink reservoir in cartridge receptacle 64b. 

[0053] As shown in Rgure 6A, cartridge receptacle 64b includes automatic alignment sensor 82. Automatic alignment 
15 sensor 82 senses a position of a dot pattern formed by printer 30. This information is used to align all print heads in 
printer 30. Also included in connection with cartridge receptacles 64a and 64b is a home location sensor (not shown); 
which is used to detect when cartridge receptacles 64a and 64b are at a home location relative to carriage 69. The posi- 
tion and significance of the home location are described in detail below. 

[0054] Returning to Figure 4, printer 30 includes wipers 84a and 84b and ink cleaning mechanism 86. Ink cleaning 
20 mechanism 86 Is disposed at home location 87 and comprises a rotary punrtp (not shown) and print head connection 
caps 88a and 88b Print head connection caps connect to print heads of cartridges installed in cartridge receptacles 
64a and 64b. respectively, during print head cleaning and at other times, such as when printer 30 is powered off. so as 
to protect the print heads. 

[0055] Line feed motor 61 drives the rotary pump of ink cleaning mechanism 86 so as to suction excess ink from a 
25 print head connected to print head connection cap 88a^ As described in more detail in section 5.0 below, ink is suc- 
tioned only from a user-designated one or ones of the cartridges. User designation is described below. 
[0056] Wipers 84a and 84b can comprise blades or the like which are driven by carriage motor 66 to wipe excess ink 
from cartrkige print heads. Specifically, wipers 84a and 84b are lifted to contact a print head after a predetermined' con- 
dition has occun^ed. For example, wipers 84a and 84b can be lifted after a predetermined number of dots have be^n 
30 printed by a print head. 

1.2 Functions 

[0057] Printer 30 includes a variety of functions and features which are available via access door 32 arKf printer 30*s 
35 front panel. A description of these functions follows. 

1.2.1 Manual Cleaning 

[0058] Printer 30 includes a manual cleaning function which can fc>e activated via its front panel. Specifically, manual 
40 cleaning is activated by pressing resume button 46 until printer 30 emits a beep which is two seconcte long. To indicate 
that manual cleaning has been activated, indicator light 43 blinks. Any medium in the process of printing is then ejected 
from eject port 40. Ink cleaning mechanism 86 then cleans, e.g.. suction ink from and wipes ink off of, the print heads 
of ink cartridges stored in cartridge receptacles 64a and 64b. and the suctioned and wiped ink is stored in a waste ink 
storage area. Thereafter, Indicator light 43 stops blinking and is turned on if no errors have occurred. In the event that 
45 a waste ink error has occurred, e.g. . the waste ink storage area is near capacity, the orange LED will illuminate Irxiicator 
light 43 and printer 30 will emit six beeping sounds. 

1 .2.2 Cartridge Replacement 

50 [0059] Printer 30 enters a cartridge replacement mode once access door 32 is opened unless any of the following 
conditions is present: printer 30 is powered off, a recording medium has been fed from a sheet feeder, printer 30 is print- 
ing or has received data from host processor 23, a paper empty error or a paper jam has occurred, the temperature of 
a print head in printer 30 is too high, or a fatal error has occurred. 

[0060] In this regard, th ' cartridg r placement mod is g neralty entered either at print ~ r setup to install either entire 
55p' Ink cartridges or ink reservoirs, or during the printer's lifetime to replace used or defective cartridges or reservoirs. At 
initial printer setup, there is no ink cartridge or reservoir in one of cartridge receptacles 64a or 64b. To make this known, 
indicator light 43 blinks. To install a cartridge or reservoir, a user opens access door 32, which, as described below, 
causes cartridge receptacles 64a and 64b to rrxsve to a center position along carriage 69. At this position, a user can 
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install an ink cartridge simply by lifting levers 72 of cartridge receptacles 64a and 64b. dropping the cartridges, print 
head first, into cartridge receptacles 64a and 64b, and closing levers 72. The process of replacing an empty or defective 
ink cartridge is identical to that described here. To replace an ink reservoir, the user can pull the defective or empty ink 
reservoir off of the cartridge, and Insert a new ink reservoir in its place. 

5 [0061 ] To terminate the cartridge replacement mode, a user need simply close access door 32. Once the replacement 
mode has been terminated, printer 30 checks the newly-installed cartridge to determine if it has been installed correctly. 
If the cartridge or reservoir is correctly installed, printer 30 causes cartridge receptacles 64a and 64b to move to home 
location 87. On the other hand, if the cartridge or reservoir is installed incorrectly, or canriot be used for some reason 
(e.g.. it is defective), then indicator light 43 illuminates orange. In addition, printer 30 emits three beeps to Indicate that 

10 there is a problem with an ink cartridge in cartridge receptacle 64b, and emits four beeps to indicate that there is a prob- 
lem with an ink cartridge in cartridge receptacle 64a. 

1.3 Ink Cartridge 

IS [0062] The printer described herein can use ink cartridges which include removable ink reservoirs for storing different 
types of ink. An example of such a cartridge is shown in Figures 7A arxi 7B. As noted above, however, the present 
invention can also be used with disposable ink cartridges that do not contain removable ink reservoirs, but instead store 
ail ink internally. An example of such a cartridge is shown in Figure 7. 

[0063] tn general, printer 30 can operate with a variety of different cartridge types. For example, printer 30 can use a 
20 cartridge which stores dye-t)ased black ink and which has a print head with 1 28 nozzles extending in the vertical direc- 
tion. An example of such a cartridge is a Canon BC-20 cartridge. A similar type cartridge may also be used which stores 
pigment black ink In this regard, generally speaking, dye-based black ink has high penetration characteristics relative 
to a recording medium. On the other hand, pigment-based black ink generally has low penetration characteristics (and 
in some cases no penetration) relative to a recording medium. 
25 [0064] Printer 30 can also operate with color ink cartridges. For example, printer 30 can operate with an ink cartridge 
which stores cyan, magenta, yellow and black inks, and which includes 136 nozzles extending in the vertical direction. 
In such a cartrklge. 24 nozzles prirrt witii cyan ink, 24 nozzles print with magenta ink, 24 nozzles print with yellow ink, 
and 64 nozzles print with black ink. An exarnple of such a cartrkige is a Canon BC-21 (e) cartrkige. - 
[0065] Still another example of an ink cartridge that may be used with printer 30 stores reduced optical density (e.g., 
30 "photo") ink, and includes 136 nozzles anranged in the vertical direction. Such a cartridge also has the same nozzle 
configuration as the color cartridge described above. 

1 .4 Print Head Structure 

35 [0066] With regard to the physical construction of the print heads of cartridges that may be used with embodiments 
of the present invention. Figure 8 shows a close-up. face-on view of nozzle configurations for a case in which printer 30. 
includes prirrt head 98 having 1 28 nozzles and arranged near-vertical, witii each nozzle closely spaced to adjacent noz- 
zles. Such an arrangement is preferred for single color (such as black) printing. The nozzles are preferably arranged at 
a slight oblique slant so that as the print head is moved across the recording medium, j tjs possible to fire the nozzle s 

40 hi ra ffld succession , rath er than all at onc e^soaaAo p rint a ve rtical line. The power and control requirements for firing 
nozzles in rapid succession are signrficantiy reduced relative to those for firing all at.once. One preferable anrangement 
of slant angle would correspond to a one pixel horizontal change for every 16 vertical nozzles, at 360 dpi resolution. 
[0067] Print head 99 has 136 nozzles, witii 24 nozzles preferably for yellow inK 24 nozzles preferably for magenta 
ink, 24 nozzles preferably for cyan ink. and 64 nozzles preferably for black inK arranged at a slight slant angle to verti- 

45 cal, one on top of another. Each color group of nozzles is separated from an adjacent group by a vertical gap corre- 
sponding to 8 nozzles. The slight slant angle is. again, arranged to provide one pixel of horizontal change for every 16 
vertical nozzles, at 360 dpi. 

1.5 Print Modes 

50 

[0068] During its operation, printer 30 includes different modes which may be set via commands issued to printer 30 
by host processor 23 (see Figure 1). tn tiiese modes, cartrklges installed in printer 30 may ^ect different-sized ink drop- 
lets to form images having different resolutions. Whether certain modes of printer 30 are available depends, in part, on 
the type of cartridge installed in printer 30. That is, print heads on some types of cartridges are capable of ejecting dif- 
55 ferent-sized droplets, e.g.. large or small ink droplets, whereas print heads on other types of cartrkiges are capable of 
ejecting droplets having a single size. 

[0069] As noted, above, different ink droplet sizes are used during different printer operational modes to form images 
having different resolutions. More specifically, ink Jet printers create images by forming dots on a page. The resolution 
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of a formed image corresponds in part to the number of dots formed and in part to the arrangement in which those dots 
are formed. In the printer of the present Invention, images can be formed at a variety of different resolutions using either 
the large or small Ink droplets described above. 

[0070] At this point, it is noted that dot allocation and arrangement during printing is limited, in part» based upon the 
5 type of paper used during printing. Specifically, plain paper can absorb approximately a maximum of tour small droplets 
in a 360 dpi pixel, whereas high resolution (hereinafter "HR-101") paper can absorb a maximum of 6 small droplets in 
a 360 dpi pixel. 

[0071 ] With the foregoing in mind. Figure 9 shows droplet arrangements for each pixel In a 1 80 horizontal (H) by 180 
vertical (V) rasterization using regular (i.e., non^^hoto) ink and any type of paper As shown in Figure 9, this arrange- 
rs ment provides for three levels, and can attain a 360(H) by 360(V) dpi printout using large droplets. 



[0072] As described in section 1 .0 above, printer 30 may use multiple print heads in different combinations, such as 
IS black-black, black-color, color-color, or color-photo, so that several print modes may be executed at different resolutions 
(e.g., 180 dpi. 360 dpi, 720 dpi). Further, print head combinations may be changed for different print modes, such as 
text, text and color, color and high quality color. As a result, printing tasks for the different modes require complex oper- 
ations that vary based on the print head combination, recording media and print quality. In the information processing 
system of Figure 1, printer parameters relating to print head configuration, print head alignment, etc. are stored in 
20 printer 30 and sent to host processor 23 based on data obtained by printer 30. Accordingly, a printer driver In host proc- 
essor 23 performs the complex processing of print data and printer set up for the various print modes and sends dic- 
tated command sequences to the printer that sirrqdtify printing execution. Advantageously, the architecture of the printer 
is simplified while the demands of the print processing on host processor 23 have little or no effect on the operation of 
host processor 23. 



[0073] v^jgure ip is a block diagram showing the internal structures of host_BrQ&essor 23 a nd printer 30. In Figure ^10, 



host processor 23 includes a central processing unit 100 such as a programmat^le microprocessor interfaced to com- 
30 puter bus 101 . Also coupled to computer bus 101 are display interface 1 02 for interfacing to display 22, printer Interfac 
104 for interfacing to printer 30 through bi-directional communication line 106, floppy disk Interface 24 for interfacing. to 
floppy disk 107, keytxjard interface 109 for interfacing to keyboard 26, and pointing device interface 1 10 for interfacing 
to pointing device 27. Disk 25 includes an operating system section for storing operating system 1 1 1 , an applications 
section for storing applications 112, and a printer driver section for storing printer driver 114. 
35 [0074] A random access main memory (hereinafter "RAM") 116 Interfaces to computer bus 101 to provide CPU 100 
with access to memory storage. In particular, when executing stored application program Instruction sequences such 
as those associated with application programs stored in applications section 1 1 2 of disk 25, CPU 1 00 loads those appli- 
cation instruction sequences from disk 25 (or other storage media such as media accessed via a network or floppy disk 
drive 24) into random access memory (hereinafter "RAM") 116 and executes those stored program instruction 
40 sequences out of RAM 116. RAM 116 provides for a print data buffer used by printer driver 114 according to the inven- 
tion, as described more fully hereinbelow. It should also be recognized that standard disk-swapping techniques availa- 
ble urxier the windowing operating system allow segments of memory, including the aforementioned print data buffer, 
to be swapped on and off of disk 25. Read only memory (hereinafter "ROM") 43 in host processor 23 stores invariant 
instruction sequences, such as start-up instruction sequences or basic input/output operating system (BIOS) 
45 sequences for operation of keyboard 26. 

[0075] As shown In Figure 10. and as previously mentioned, disk 25 stores program instruction sequences for a win- 
dowing operating system and for various application programs such as graphics application programs, drawing appli- 
cation programs, desktop publishing application programs, and the like. In addition, disk 25 also stores color image files 
such as might be displayed by display 22 or printed by printer 30 under control of a designated application program. 
50 Disk 25 also stores a color monitor driver in other drivers section 119 which controls how multi-level RGB color primary 
values are provided to display interface 102. Printer driver 114 controls printer 30 for both black and color printing and 
supplies print data for print out according to the configuration of printer 30. Print data is transferred to printer 30. and 
control signals are exchanged between host processor 23 and printer 30, through printer interface 104 connected to 
line 106 under control of printer driver 114. Otiier device drivers ar also stored on disk 25, for providing appropriate 
55 signals to various devices, such as network devices, facsimile devices, and the like, connected to host processor 23. 
[0076] Ordinarily, application programs and drivers stored on disk 25 need first to be installed by th user onto disk 
25 from other computer-readable media on which those programs and drivers are initially stored. For example. It Is cus- 
tomary for a user to purchase a floppy disk, or other computer-readable media such as CD-ROM, on which a copy of a 
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printer driver is stored. The user would then install the printer driver onto disk 25 through well-known techniques by 
which the printer driver is copied onto disk 25. At the same time, it is also possible for the user, via a modem interface 
(not shown) or via a network (not shown), to download a printer driver, such as by downloading from a file server or from 
a computerized bulletin board. 

5 [0077] Referring again to Figure 1 0, printer 30 includes CPU 1 2 1 such as an 8-bit or a 1 6-bit microprocessor including 
programmable timer and interrupt controller. ROM 122, control logic 124, and I/O ports unit 127 connected to bus 126. 
Also connected to control logic 124 is RAM 129. Control logic 124 includes controllers for line feed motor 61, for print 
image buffer storage in RAM 129, for heat pulse generation, and for head data. Control logic 124 also provides control 
signals for nozzles tn print heads 130a and 130b of print engine 131 , carriage motor 66, line feed motor 61 , and print 

10 data for print heads 130a and 130b, and receives information from print engine 131 for alignment of print heads 130a 
and 130b through I/O ports unit 127. EEPROM 132 is connected to I/O ports unit 127 to provide non-volatile memory 
for printer information such as print head configuration and print head alignment parameters. EEPROM 132 also stores 
parameters that identify the printer, the driver, the print heads, alignment of the print heads, the status of ink in the car- 
tridges, etc., which are sent to printer driver 114 of host processor 23 to inform host processor 23 of the operational 

15 parameters of printer 30. 

[0078] I/O ports unit 127 is coupled to print engine 131 in which a pair of print heads 130a arxi 130b (which would be 
stored in cartridge receptacles 64a and 64b. respectively) perform recording on a recording medium by sccuining 
across the recording medium while printing using print data from a print buffer in RAM 129. Control logic 124 is also 
coupled to printer interface 104 of host processor 23 via communication line 106 for exchange of control signals and to 

20 receive print data and print data addresses. ROM 122 stores font data, program instruction sequences used to control 
printer 30. and other invariant data for printer operation. RAM 129 stores print data in a print buffer defined by printer 
driver 1 14 for print heads 130a and 130b and other information for printer operation. 

[0079] Print heads 130a and 130b of print engine 131 correspond to ink cartridges that are stored in cartridge recep- 
tacles 64a and 64b, respectively. Sensors generally indicated as 134 are arranged in print engine 131 to detect printer 

25 status and to measure temperature and other quantities that affect printing. A photo sensor (e.g.. automatic alignment 
sensor 82 shown in Figure 6A) in cartridge receptacles 64 measures print density and dot locations for automatic align- 
ment. Sensors 134 are also arranged in print engine 131 to detect other conditions such as the open or closed status 
of access cover 32, presence of recording media, etc. In addition, diode sensors, including a thermistor, are located in 
print heads 130a and 130b to measure print head temperature, which is transrnitted to I/O ports unit 127. 

30 [0080] I/O ports unit 127 also receives input from switches 133 such as power button 44 and resume button 46 and 
delivers control signals to LEDs 135 to light indicator light 43, to buzzer 128, and to line feed motor 61 and carriage 
motor 66 through line feed motor driver 61a and carriage motor driver 66a, respectively. As described above. fc>uzzer 
1 28 may comprise a speaker. 

[0081 ] Although Figure 10 shows individual components of printer 30 as separate and distinct from one another, it is 
35 preferable that some of the components be combined. For example, control logic 124 may be combined with I/O ports 
1 27 in an ASIC to simplify interconnections for the functions of printer 30. 

2.2 System Function 

40 [0082] Figure 1 1 shows a high-level functional block diagram that illustrates the interaction between host processor 
23 and printer 30. As illustrated in Figure 11, when a print instruction is issued from image processing application pro- 
gram 1 12a stored in application section 1 12 of disk 25, operating system 11 1 issues graphics device interface calls to 
printer driver 114. Printer driver 114 responds by generating print data corresponding to the print instruction and stores 
the print data in print data store 1 36. Print data store 1 36 may reside in RAM 1 1 6 or in disk 25, or through disk swapping 

45 operations of operating system 111 may initially be stored in RPM 116 and swapped in and out of disk 25. Thereafter, 
printer driver 114 obtains print data from print data store .136 and transmits the print data through printer interface 104. 
to bi-directional communication line 106. and to print buffer 139 through printer control 140. Print buffer 139 resides in 
RAM 129 and printer control 140 resides in control logic 124 and CPU 121 of Figure 10. Printer control 140 processes 
the print data in print buffer 139 responsive to commands received from host processor 23 and performs printing tasks 

so under control of instructions stored in ROM 122 (see Figure 10) to provide appropriate print head and other control sig- 
nals to print engine 131 for recording images onto recording media. 

[0083] Print buffer 1 39 has a first section for storing print data to be printed by one of print heads 1 30a and 1 30b. and 
a second section for storing print data to be printed by the other one of print heads 130a and 130b. Each print buffer 
section has storage locations corresponding to the number of print positions of the associated print head. These stor- 
55 age locations are defined by printer driver 114 according to a resolution selected for printing. Each print buffer section 
also includes additional storage locations for transfer of print data during ramp-up of print heads 1 30a and 1 30b to print- 
ing speed. Print data is transferred from print data store 1 36 in host processor 23 to storage locations of print buffer 1 39 
that are addressed by printer driver 1 14. As a result, print data for a next scan may be inserted into vacant storage loca- 
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tions in print buffer 139 both during ramp up and during printing of a current scan. 
2.3 Control Logic 

5 [0084] Figure 12 depicts a block diagram of control logic 124 and I/O ports unit 127 from Figure 10. As mentioned 
above. I/O ports unit may be, alternatively, included within control logic 124. In Figure 10. user logic bus 146 is con- 
nected to printer bus 126 for communication with printer GPU 121. Bus 146 is coupled to host computer interface 141 
which is connected to bi-directional line 106 for can^ying out bi-directional such as IEEE-1284 protocol communication. 
Accordingly, bi-directional communication line 106 is also coupled to printer interface 104 of host processor 23. Host 

10 computer interface 141 is connected to bus 146 and to DRAM Ixjs arbiter/controller 144 for controlling RAM 129 which 
includes print buffer 139 (see Figures 10 and 1 1). Data decompressor 148 is connected between bus 146 and DRA!\/I 
bus arbiter/controller 144 to decompress print data when processing. Also coupled to bus 146 are line feed motor con- 
troller 147 that is connected to line feed motor driver 61a of Figure 10. image buffer controller 152 which provides serial 
control signals and head data signals for each of print heads 130a and 130b. and heat pulse generator 154 which pro- 

15 vides block control signals and analog heat pulses for each of print heads 130a and 1 30b. Can-iage motor control is per- 
formed by CPU 121 through I/O ports unit 127 arxl carriage motor driver 66a since line feed motor 61 and carriage 
motor 66 may operate concurrently. 

[0085] Control logic 124 operates to receive commands from host processor 23 for use in CPU 121. and to serKj 
printer status and other response signals to host processor 23 through host computer interface 141 and bi-directional 

20 communication line 106. Print data and print buffer memory addresses for print data received from host processor 23 
are sent to print buffer 139 in RAM 129 via DRAM bus arbiter/controller 144, and the addressed print data from print 
buffer 139 is transferred through controller 144 to print engine 131 for printing by print heads 130a and 130b. In this 
regard, heat pulse generator 1 54 generates analog heat pulses required for printing the print data. 
[0086] Figure 1 3 shows the memory architecture for printer 30. As shown in Figure 1 3, EEPROM 1 32, RAM 1 29. ROM 

25 122 and temporary storage 161 for control logic 124 form a memory structure with a single addressing arrangement. 
Referring to Rgure 13. EEPROM 132, shown as non-volatile memory section 159. stores a set of parameters that are 
used by host processor 23 and that identify printer and print heads; print head status, print head alignment, and other 
print head characteristics. EEPROM 132 also stores another set of parameters, such as clean time, auto-alignmeht 
sensor data, etc.. which are used by printer 30. ROM 122, shown as memory section 160. stores information for printer 

30 operation that is invariant, such as program sequences for printer tasks and print head operation temperature tat>les 
that are used to control the generation of nozzle heat pulses, etc. A rarxJom access memory section 161 stores tempo- 
rary operational information for control logic 124. and memory section 162 conresporxiing to RAM 129 includes storage 
for variablie operational data for printer tasks and print kxjffer 139. 

35 2.4 General Operation 

[0087] Figure 14 is a fk)wchart illustrating the genera! operation of the information processing system shown in the 
block diagram of Figure 10. After power istumed on in prirrter 30 in step S1401 of Figure 14. printer 70 is initialized in 
step SI 402. In the initialization, as discussed in greater detail in section 3.2 below and shown in Figures 19 and 20. 

40 CPU 121, control logic 1 24 and a system timer are set to an initial state. In addition, ROM 121, RAM 1 29 and EEPROM 
132 of printer 30 are checked and interrupt request levels in CPU 121 are assigned on application of power to printer 
30. When printer 30 is set to its on state, EEPROM 132 is read by printer driver 1 14. controller tasks are started by 
printer CPU 1 21 such as resetting the printer, deternnining if print head cleaning shouki be performed based on the sys- 
tem timer, etc. Also in the initialization process of step SI 402, a data compression mode is selected, heat pulses for 

45 print heads 130a and 130b are defined, buffer control is defined, pririt buffer 139 is cleared, and messages are dis- 
played indicating the status of printer 30. 

[0088] N^. step SI 403 is performed. In step SI 403. printer driver 114 calculates printer parameters from data 
obtained by printer CPU 121 based on printer measurements related to head configuration and alignment if it is deter- 
mined that the print head configuration has changed. The alignment system is described more fully in U.S. Patent Appli- 
50 cation No. 08/901,560. entitied "Auto- Alignment System For A Printing Device", filed on July 28, 1997 (co-pending 
European Application No. 98305955.1). 

[0089] Following step S1403. processing proceeds to step S1404. in which it is determined if printer 30 is on-line. 
Once it is determined tiiat printer 30 is on-line, processing proceeds to step SI 405. in which the calculated printer 
parameters are registered in printer EEPROM 132. 
55 [0090] Specifically, when printer 30 is determined to be on-line, the printer parameters stored In the EEPROM 132 
are registered by printer driver 1 1 4 in step Si 405. The parameters are then sent, in step SI 405. by CPU 1 21 for storage 
in host processor 23 so that printer driver 114 can generate appropriate commands for printer operation. Such com- 
mands are indicated in the steps of the dashed box of Figure 1 4 and take into account the current identification of printer 
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30. the print head configuration, print head alignment and cartridge ink status. 

[0091] A method in accordance with step 81 405 for sending the parameters comprises sending data representative 
of the printer parameters for the current head configuration to the host processor. A printer driver in the host processor 
generates commands for controlling printer function according to the characteristics of the attached print devices and 
5 sends the generated commands to the printer controller. The commands include parameters corresponding to the char- 
acteristics of the attached print devices to allow control of printer operations for a variety of multiple print device config- 
urations. The sending of printer parameter data to the printer driver in the host processor and the generation and 
sending of commands are described in greater detail in section 6.0. 

[0092] With regard to print head cleaning, cleaning can be scheduled at various times during operation of the printer, 
10 such as in step S1405A. The method for scheduling cleaning a print head in accordance with step S1405A includes 
receiving real time/date (time and/or date) information from an external source, storing the real time/date information in 
a volatile memory, storing, in a non-volatile RAM, a last cleaning time for at least one print head in the ink jet printer, 
and calculating an elapsed time by subtracting the stored real time/date information and the stored last cleaning time. 
The method further includes comparing the calculated elapsed time to a predetermined elapsed time, controlling the at 
15 least one print head to perform a cleaning process when the calculated elapsed time is greater than or equal to the pre- 
determined elapsed time, and storing, in the non-volatile memory, the latest last time for cleaning the at least one print 
head. When the calculated elapsed time is less than the predetermined elapsed time, the method waits to perform a 
cleaning t>ased on either an elapsed intemaf time, a comparison of the next downloaded time, or an occurrence of a 
cleaning event such as replacing a print head. The scheduling of print head cleaning is described in greater detail in 
20 section 7.0 below. 

[0093] The parameters registered in step S1405 are used to control print head operation. A method in accordance 
with step SI 405 for controlling a print head of an image printing device having at least one print head includes obtaining 
profile information of the at least one print head comprising the parameters registered in step S1405. The method 
includes storing the profile parameters in a non-volatile RAM and outputting, upon request, the profile information to a 
25 host processor connected to the image printing device. The host processor utilizes the print head profile information to 
produce compensation parameters which connpensate print information to be sent from the host processor to the print 
head for printing. This method is descrbed In greater detail in section 8.0. 

[0094] After registration of the printer parameter information in step S1405, and cleaning scheduling in step S1405A, 
the status of each of print head cartridges 300a and 300b (see Rgure 4) is checked in step 31406. This is done by 
30 ascertaining whether access door 32 has been opened and closed and detecting whether one or more of the ink car- 
tridges or ink reservoirs has been changed. If a cartridge or reservoir has been changed, a cleaning operation is per-, 
formed on the corresponding print head, in which the nozzles of the print head are cleaned. 

[0095] A device used in step S1406 for cleaning a print head during ink reservoir/cartridge change comprises a car- 
tridge receptacle which is mounted on a carriage for releasably receiving a cartridge having a prirrt head and at least 

35 one removable ink reservoir. The receptacle includes a pivoting lever which permits removal of the at least orie ink res^ 
ervoir. The lever extends over at least a portion of the at least one ink reservoir so as to prevent access to the at least 
one ink reservoir until such time as the lever is pivoted away from the at least one ink reservoir. When the lever is piv- 
oted away from the at least one ink reservoir and then is pivoted over the at least a portiion of the at least one ink res- 
ervoir, a signal is output which prompts cleaning of the print head. Print head cleaning arrangements are described in 

40 greater detail in section 5.0. 

[0096] Following the cartridge change processing performed in step S1406. processing proceeds to step S1407. In 
step SI 407, it is determined whether an interrupt has been requested by printer 30 for operations such as print head 
heater control. In response to such an interrupt request, the requested printer operation is performed in step S1408. 
Thereafter, processing returns to step 81 406. 

45 [0097] If an interrupt has not been requested by the printer in step SI 407, processing proceeds to step SI 409. In step 
SI 409, it is determined if printer driver 114 has requested a command sequence. In the system of Figure 10, tasks of 
printer 30 are controlled by commands from printer driver 114 which have been generated in accordance with parame- 
ter and status information received from printer 30. When a user interface sequence is selected, step S1 41 4 is entered 
and the processing shown in Figure 15 is executed. 

50 [0098] Upon selection of the user interface, in step S1501 , the current status of printer 30 is requested and received 
from printer 30 over bi-directional communication line 106. Then, in step SI 502, it is determined if printer 30 has a new 
print head. When a new print head is detected, an automatic alignment is performed in step SI 503. and in step SI 504 
the status information of printer 30 is stored in printer driver 114. Otherwise, the latest printer driver information is 
obtained for the user in step 81505. In either event, it is then determined in step S1506 if the page to be printed is a 

55 utility page for head exchange and/or alignment or the top page of a documerrt. When a utility page is selected, the cur- 
rent head configuration is displayed in step SI 507 and the user selects whether to enable or disable printer 30 in step 
SI 508. Selection step Si 509 is then entered and the user may select alignment by step SI 510, head exchange and 
alignment by steps SI 510 and SI 511 followed by storing of printer status information in step SI 51 2, a recovery oper- 
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ation to clean print heads 130a and 130b by step S1513. or cancellation of the user interface in step 1514. Once the 
tasks selected in step SI 509 are performed, control is returned to step SI 409 of Figure 14. 

[0099] When the print mode is selected in st^ S1 506 of Figure 1 5. the current head configuration is displayed to the 
user (step SI 51 5). After operation of an enable-disable button in step 8151 6» the user may select, in step 81517, print, 

5 media type, media size, target image, custom page setting, utility or cancel operations. The selection of media type 
(step S1518), media size (step S1519), target image (step S1520) (i.e., text and color or photo-color), custorn paper 
size (step SI 521). and custom setting page (step 81 522) causes information to be stored in printer driver 114 which 
controls the print parameters and print data for the print sequence to be performed. Upon completion of the user selec- 
tions by means of keyboard and pointer entry on the user interface display, control is returned to step 81409 and is 

10 directed to use print command sequence step 81410. 

[0100] If a print sequence is selected in step 81 409, processing proceeds to step 81410. In step 81 41 0, printer driver 
114 generates a sequence of commands based on print head configuration, print head alignment, media type and size 
and target image information stored therein. These commands are sent to printer control 140 (see Figure 1 1) in printer 
30. In the printer, printer control 140 receives the commands and the firmware from printer ROM 122 and causes exe- 

15 cution of command tasks in print engine 131 . 

[0101] The print command sequence includes transferring print data from print driver 1 14 to print buffer 139 which is 
defined for each print job. The print data transfer is performed without a receiving buffer in printer 30. Print data for a 
next scan is sent to empty storage locations of the current scan in prirrt buffer 139 during ramp-up of the print heads in 
the current scan. 

20 [0102] In brief, the print buffer to which commands are transferred in step 81410 includes a set of storage locations 
corresponding to the print positions of the current scan for each print head. The printer driver identifies empty storage 
locations of the current scan in the print buffer arxi sends print data for the next scan of the print head to the Identified 
empty storage locations during the ramp-up period of the current scan of the print head. The print data transfer in the 
print command sequence according to the invention is described more fully below in section 9.0. 

25 [0103] The command sequence of step 81410 includes commands to set print resolution of print heads 130a and 
130b. These commands are set by controlling the size of ink droplets based on digital data stored in a print buffer for a 
print head and the order in which the print data is read out of the print buffer for the print head. Specifically, a method 
for controlling print resolution in a printer having first and second print heads includes controlling resolution of the-first 
and second heads independently of each other. For ink jet type print heads which eject ink droplets based on digital 

30 data stored in a print buffer, resolution is controlled by controlling ink droplet size and by controlling readout order from 
the print buffer, with droplet size and readout order being controlled independently for each print head. Print resolution 
control is described in greater detail in section 10.0. > ''-"'^ 

[0104] Further in tiie print command sequence of step 81410, printer driver 114 selects the type of ink that is to be 
used in printing a target pixel based on an analysis multi-level image data of adjacent pixels. As an example, a dye- 

35 based ink may be selected for a black target pixel surrounded by color pixels in an image while a pigment-based ink 
may be selected for a black target pixel surrounded by black pixels. 

[0105] In summary, a method, in accordance with the present invention, of controlling printing of pixels corresponding 
to a multi-level image includes determining, based on multiTle/el image data for a target pixel and multi-level image data 
for pixels adjacent to the target pixel, whether the target pixel should be printed using a dye-based ink or whetfier the 

40 target pixel should be printed using a pigmerrt-based ink, instructing a printer to print the target pixel using the dye- 
based ink in a case that it is determined that the target pixel should be printed using the dye-based ink, and instructing 
the printer to print the target pixel using the pigment-based ink in a case that it is determined that the target pixel shoukJ 
be printed using the pigment-based ink; The control of pixel printing is described in greater detail in section 11 .0. 
[0106] Upon completion of printing one page, flow proceeds to step 8141 1 of Figure 14, wherein the page is output 

45 from printer 30 responsive to a paper eject command. Printer 30 then ejects the page to a pair of angled retractable 
flaps adjustably positioned by springs on a tray as described in section 4.0. While moving onto tiie ti^ay during printing, 
the level at which a page slides onto previously-ejected pages is maintained by downward movement the flaps so that 
the page does not bend in the print head area. Such berxiing may cause distortion of an image being printed. Moreover, 
the paper ejection tray has a structure which facilitates storage and setup. 

50 [0107] To this end, this aspect of the invention is an ejection tray for a printer having a housing defining a media feed 
portion and a media eject port, where the housing is adapted to house a print engine for printing onto recording media. 
The ejection tray includes a base slidably receivable in the printer's housing at a position laterally distanced from the 
media eject port. The base includes at least a pair of recesses extending in a sliding direction of the base. A pair of flaps 
are also included in the ejection tray. The pair of flaps each have at least one width portion corresponding to the lateral 

55 distance between the base and the eject port. Each flap is hinged Into a corresponding recess of the base and is biased 
in an upward direction via a spring which provides for angular motion of the flap relative to the base. Upon sliding action 
of tiie base out of the housing, the flaps are biased upward out of the recesses to a height corresponding to the position 
of the media eject port. 
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[0108] Figure 16 is a flowchart that illustrates in greater detail a command sequence generated by printer driver 114 
for printing and operating printer 30. In Figure 16, the print command sequence is started by a printer initialization com- 
mand in step S1601. which is sent to printer control 140 to reset printer operation. A paper load command (step S1602) 
is then provided to printer control 140, which selects a load paper operation in selection step SI 603 and executes a 

5 Start paper load (step S1604). When a paper load end is detected in printer control 140 in step S1605, a signal indicat- 
ing end paper load is sent to printer driver 114, and the print data is prepared for a first scan of print heads 130a and 
1 30b in step SI 606. Printer control 1 40 is notified of this scan preparation. The preparation of print data in printer driver 
1 14 is described more fully in U.S. Patent Application No. 08/901,719, entitled "Print Driver For A Color Printer", filed 
July 28, 1997 (European Application No. 98305967.6). If no print data for the scan is determined in decision step 

10 S1607. a virtual skip is performed in printer driver 1 14 in step S1608. Control is returned to step S1607 when a page 
finish is not detected in step SI 609. Until the page finish is detected, steps SI 610 through SI 61 4 and Si 608 are per- 
formed. 

[01 09] In step SI 61 0, an actual skip command is provided by printer driver 1 1 4 to printer control 1 40 for printing cor- 
rect print data. Printer control 140 selects the actual skip operation (step SI 603) and executes the actual skip (step 

15 81615). Scan setting is then performed (step SI 611) in printer driver 1 1 4, and printer control 140 is notified. Next, print 
data generated in printer driver 114 and print buffer addresses for the print data are transferred to printer control 140 
which stores this information in print buffer 139 (step S1612). The next scan is then prepared in printer driver 1 14, and 
printer control 140 is notified (stepS1613). Then, a print command generated in printer driver 114 is sent to printer con- 
trol 140. In response, printer control 140 selects a print operation in step SI 61 9 and executes the print task in step 

20 SI 61 4. A virtual skip is then performed by printer driver 1 1 4 in step Si 608 to keep track of the lines of the page being 
printed. When a page finish is determined in decision step S1609, a page eject command is sent by printer driver 114 
to printer control 140. which selects a page eject operation (step SI 61 6) and starts page eject (step S161 7). Upon com- 
pletion of the page eject (step S1618), printer driver 1 14 is notified of the completion of the page eject and control is 
passed to step S1409 of Figure 14. 

25 [01 1 0] Figure 1 7 is a flowchart Illustrating the set of comniands used in scan setting step SI 61 1 for the current scan 
of Figure 16. Referring to Figure 17, a [SPEED] command is issued in step SI 701 to set the scan speed, a [DROP] 
command is issued (step SI 702) to set the droplet size for one print head (A) and anotiier [DROP] command is issued 
(step SI 703) to set the droplet size for the otiier print head (B). In steps SI 704 and SI 705, a [SELECT_PULSE] com- 
mand is issued to set a heat pulse for printing and a [PCR] command is issued to set a pulse control ratio for tempera- 

30 ture table adjustment [SELECTjCONTROL] commands are issued in steps SI 706 and SI 707 to select the buffer 
control for each prini head to determine a firing time of print head nozzles. [DEFiNE_BUF] commands are issued in 
steps S1708 and S1709 to define tiie print txjffer for each of print heads 130a and 130b. Accordingly, each aspect of a 
printer operation such as scan setting Is controlled by host processor printer driver 114 taking into account the print 
head configuration and the print mode. The tasks performed by primer 30 are thereby defined in detail by printer driver 

35 1 14 so that the printer architecture is substantially simplified and less costiy. 

[01 11 ] An example of the command sequence from the host processor 23 to printer 30 to print a page in color mode 
with two color print heads is set forth in Table A shown in Figure 18. Initially as indicated in Table A, the current time is 
set by a [UCT] command and printer 30 is reset by a [RESET] command. Data compression is selected to pack the print 
data by a [COMPRESS] command. Print buffers for print heads 130a and 130b are defined by [DEFINE_BUF] com- 

40 mands. The heat pulse and buffer control tables are defined for. the color mode of the print head configuration by 
[DEFINE_PULSE1 and [DEFINE_CONTRpL] commands. 

[0112] After the printer tasks are executed for tiie foregoing Initializing commands, a paper load command [LOAD] to 
load a page or other print medium and a raster skip command [SKIP] to skip to the print position of the first print head 
scan are sent to printer 30, and the print direction and edges for printing of print heads 130a and 130b are set for the 

45 first scan. A loop of commands is then sent to control printer tasks for printing the lines of the page. In the first portion 
of the loop for each line, the scanning parameters for the line are set as described with respect to Figure 1 7. Following 
completion of the printer tasks for the select buffer control table commands [SELECTJCONTROL], the print data blocks 
are selected by the [BLOCK] command, and the print colors are selected and transmitted by repeated select color 
[COLOR] and data transmission [DATA] commands according to the determined print areas for print heads 130a and 

50 130b. 

[0113] The direction of the second scan and the left and right edges of the print areas for the second scan are then 
set by the [DIRECTION] and [EDGE] commands. At this time, a [PRINT] command is transferred from host processor 
23 to printer 30 to execute printing for the first scan, and a [SKIP] command is sent to skip to the print position of the 
second scan. When the last line has been printed, a paper eject command is given to printer 30 to execute paper ejec- 
55 tion 

[01 14] As can be seen from the command sequences for set scan operations and the example of the printing opera- 
tions according to the invention, each aspect of printer operation, such as scan setting or printing, is controlled by 
printer driver 114 taking into account print head configuration and the print mode. The tasks to be performed by printer 
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30 are thereby defined in detail by printer driver 114 so that the printer architecture is substantially simplified to be less 
costly. 

[0115] Returning to Figure 14. when a printer status request is.determined in step S1409, flow proceeds to step 
S1412. In step S1412, a printer status command sequence is performed. The status commands that provide requests 

5 for printer status information are described in detail in section 3.6. In general, each of the status commands is sent from 
host processor 23 to printer 30 to request the information on printer operation or information stored in printer 30. For 
example, a base status command [BASE-STATUS] requests the current status of the printer. In response, printer 30 
returns one data byte indicating one of the following: printing status, whether print buffer 139 can or cannot receive data, 
whether printer 30 is busy performing start-up, cartridge replacement, print head cleaning, test printing, etc., and 

10 whether an error or alarm has been detected. A [HEAD] command requests return of print head configuration, arxl a 
[DATA_SEND] command requests return of EEPROM data to host processor 23. After return of the requested data in 
step 81412. control is returned to step 81406. 

3.0 Architecture of Printer Software 

IS 

[0116] Control over functionality of printer 30 is effected by individual programs executing on CPU 121 . The individual 
programs include Initialization routines such as routines executed on power-on, tasks to interpret commands received 
from host processor 23, interrupt handlers such as handlers to process real time hardware interrupts, and cyclic han- 
dlers that handle cyclic processes such as handlers for control over bi-directional communications with host processor 
20 23. 

[0117] Printer CPU 121 further executes an operating system so as to coordinate execution of each of the individual 
programs (i.e.. tiie initialization routines, the tasks, the interrupt handlers, and the cyclic handlers). The operating sys- 
tem is responsible for inter-program communication through messaging arxi the like, and inter-program switching so as 
to switch execution from one program to another when appropriate. Details of the operating system follow. 

25 

3.1 Operating System 

[0118] The operating system is a real-time operating system (or "kernel" or "monitor") created to modularize printer 
control programs and to facilitate maintenance, inheritance, and expansion. The real-time operating system is system 
30 software that provides for a preemptive mutti-task software environment, in which a currentiy executing program can be 
suspended in favor of a switch to ainother program with a higher priority. 

[0119] The operating system allows for four different types of programs, each of which is executed by the operating 
system in accordance with its specif ic type. The types are Initialization routines, tasks, interrupt handlers, and cyclic 
handlers. Initialization routines are routines scheduled by the operating system immediately after printer 30 is reset but 
35 after the operating system initializes itself. Tasks are ordinary programs (sometimes called "execution units") of contin- 
uous processing that are executed sequentially. Thus, tasks are one or more sequences of instructions handled by the 
operating system as units of work executed by CPU 121 in a multiple-programming or multiple-processing environment. 
An illusion of concurrent processing is created by the operating system by scheduling processing In individual task 
units: 

40 [0120] An Interrupt handler is a (usually short) program unit that is activated by the operating system immediately 
upon receipt of a hardware intenxipt. Cyclic handlers are similar to interrupt handlers, but rather than being activated by 
a hardware interrupt, cyclic handlers are activated by a tinier interrupt of the operating system. 
[0121] When printer 30 is reset, execution of the operating system is the first software executed by CPU 121. CPU 
registers are set according to predefined requirements, and then user-defined initialization routines are executed if any 

45 exist. Thereafter, control reverts to the operating system, which activates each of the tasks in the system. One such task 
is a start task. After tiie start task begins, tiie operating system is activated each time a system call is issued or an inter- 
rupt occurs. After executing tiie system call; or handling the interrupt, execution reverts back to the operating system, 
which schedules tasks so as to execute tiie executable task with the highest priority. 

[0122] Scheduling of tasks involves a determination of which task is executed if there are several tasks currentiy eli- 
50 gible for execution. Tasks are scheduled according to an assigned priority in which a higher priority task is executed 
before all other lower priority tasks. Tasks eligible for execution but not currentiy being executed because of their lower 
priority level are placed in a ready queue based on their priorities. . 

[0123] As each task becomes newly eligible for execution, it is placed at the end of the ready queue. Scheduling is 
then performed when returning from a system call issued by a task or when returning from interrupt processing to a 
55 task, t)Oth of which can cause new tasks to be entered into a queue or can cause a change in priority of tasks already 
existing in the queue. Scheduling orders the tasks in the task queue based on each task's priority arxJ makes the task 
with the highest priority the currentiy executable run task. If there are two or more tasks in tiie ready queue of the same 
priority, the decision as to which task shoukJ be selected is made based on which task first entered into the queue. 
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[0124] The operating system uses semaphores as one basic means of communication between tasks and for control 
or synchronization between tasks. Tasks can also communicate and transfer data therebetween using messages. Mes- 
sages are sent to mailboxes by one tasK and a task that needs to receive the message issues a receive request to the 
mailbox so as to obtain the message. 
5 [0125] The operating system further uses event flags to synchronize tasks. Any task desiring to be released from a 
wait state based on a certain event can register an event flag pattern, upon the occurrence of which the operating sys- 
tem will release the task from the wait state. 

[0126] Interrupt management by the operating system is provided by an interrupt handler and by interrupt permission 
level settings. Time management is provided by the operating system's actuation of an interrupt handler t>ased on the 

10 system timer 

[0127] Cyclic handlers carry out processing at each of specified time intervals, based on cyclic handlers registered 
with the operating system. Typically, a cydic handler is a short program that specifies a task that is performed at each 
of specified time intervals. 

[0128] Initialization routines, tasks, interrupt handlers, and cyclic handlers that are preferred for printer 30 are 
75 described in the following sections. 

3.2 Initialization 

[0129] During power-up, initialization functions are performed to initialize printer 30. such as initializing control logic 

20 124. checking ROM 122. checking RAM 129. and checking EEPROM 132. 

[0130] Figures 19 and 20 illustrate a hard power-on sequence and a soft power-on sequence, respectively, in this 
regard, it is noted that so long as power is supplied to printer 30. CPU 121 is executing software regardless of the status 
of power button 44. Thus, a "hard power-on** refers to initial application of power to printer 30. Thereafter, user activation 
of power button 44 simply causes a soft power-on or soft power-off. This arrangement is preferred, since it allows printer 

25 30 to monitor ongoing events (such as elapsed time) even when printer 30 is "ofT. 

[0131] Referring to Figure 19, which shows a hard power-on sequence, upon initial application of power, step SI 901 
performs memory checks such as a ROM check, a F^M check, and an EEPROM check. Step SI 902 initializes software 
tasks, and in step S1903. CPU 121 enters an idle loop, awaiting a soft power on. 

[0132] Figure 20 indicates the soft power-on sequence. Step S2001 performs mechanical initialization of printer 
30 engine 131, such as a reset to the home position, step S2002 starts the software control tasks including Centronics 
communication tasks, and step S2003 enters the main processing mode. 

[0133] Figure 21 details a soft power-off sequence. Step S2101 terminates all software tasks, and step S2102 enters 
an idle loop during which, in step S2103. printer 30 awaits the next soft power-on sequence. 

35 3.3 Tasks 

[0134] In the preferred embodiment of the invention, printer tasks are designed to isolate functionality, so that each 
task is responsible for a single cohesive aspect of printer control. Generally speaking, the tasks can be divided into 
three conceptual groups, namely engine tasks, controller tasks, and miscellaneous tasks. 
40 [0135] With respect to the engine-related tasks, tasks are provided to control carriage motor 66 for carriage move- 
ment, to control line feed motor 61 for paper advance., and to corrtrol both paper feeding and cleaning operations for 
print heads 130a and 130b, such as ink suction, purgirig, and the like. Other tasks transmit messages from print engine 
131 to other tasks, and control printer engine 131 based on a message from another task. 

[0136] With respect to the control tasks, tasks are provided to interpret commands received from host processor 23; 

45 these commands are described in detail below in section 3.6. Test-related tasks may be provided if desired. 

[0137] With respect to the miscellaneous tasks, an initializer task, which was discussed above in section 3.2, initial- 
izes printer 30. Other tasks are provided to control displays on printer 30, to scan key switches corresponding to tHJttons 
on the printer 30's front panel and detect their status, to initialize hardware related to host computer interface 141 and 
I/O ports unit 127, to control Centronics output signals, and to interpret and transmit those signals to other tasks. A task 

so is provided to control the engine control task and the communications tasks. In addition, this task initiates, susperxis 
and resumes other tasks. An idle task basically does nothing and is provided for use by the operating system when no 
other tasks are queued in a wait state. 

[0138] Interface and other communications between tasks are accomplished through use of mailboxes into which 
messages are placed and semaphores to coordinate message communication. This arrangement is illustrated in Figure 
55 22. Shown in Figure 22 are controller tasks 201 . user interface tasks 202, bi-directional communications tasks 204. mis- 
cellaneous tasks 205, arKi engine tasks 206. Each task in the task group has an associated mailbox, which are illus- 
trated diagrammatically in Figure 22. witii 210 indicating mailboxes for each task in tiie controller tasks 201. 213 
indicating mailboxes for each task in user interface tasks 202. 215 indicating mailboxes for each task in communications 
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task 204. 217 indicating mailboxes for each task in miscellaneous tasks 205. and 21 9 indicating mailboxes for each task 
in engine tasks 206. With the exception of engine tasks 206. coordination of messages sent to, and retrieved from, the 
mailboxes are controlled by semaphores. For the engine tasks 206. no semaphores are used since a detection of mem- 
ory usage is sufficient 

5 [0139] Each mailbox is adapted to receive messages from each of the other tasks and is further adapted to deliver 
messages to its associated task. Thus, mailbox 210 can receive messages from any of user interface tasks 202. com- 
munications tasks 204, miscellaneous tasks 205, and engine tasks 206; and can deliver those messages to its associ- 
ated task in task group 201. Likewise, mailbox 213 is adapted to receive messages from any of controller tasks 201. 
communications tasks 204, miscellaneous tasks 205. and engine tasks 206; and to deliver those messages to the asso- 

10 ciated tasks in user interface task 202. Likewise, mailbox 215 is adapted to receive messages from any of controller 
tasks 201 , user interface tasks 202. miscellaneous tasks 205. and engine tasks 206; and to deliver those messages to 
the communications task 204. Likewise, mailbox 217 is adapted to receive messages from any of controller tasks 201, 
user interface tasks, communications tasks 204, and engine tasks 206; and to deliver those messages to the associ- 
ated tasks in miscellaneous task group 205. Finally, mailbox 219 is adapted to receive messages from any of controller 

15 tasks 201 . user interface tasks 202. communications tasks 204, and miscellaneous tasks 205; and to deliver those mes- 
sages to the associated tasks in engine tasks 206. 

3.4 interrupt Handlers 

20 [0140] Although the operating system can accommodate interrupt harxilers such as handlers for periodic clock inter- 
rupts, such cydic events can also be handled with cyclic handlers. 

3.5 Cyclic Handlers 

25 [0141] Cyclic handlers are provided for communications task 204 and for user interface tasks 202, as shown and 
described above in connection with Figure 22. ^- • - 

[0142] In addition, a cyclic handler is provided for controller timer operations. Figure 23 is a f lovv diagram illustrating 
controller timer control according to this cyclic handler. As shown in Figure 23. upon receipt of a 10 ms interrupti sub 
heater control is effected. The purpose of sub heater control is to drive the temperature of each print head in printer 30 

30 (namely, print heads 130a and 130b) toward a target temperature. This is done by setting a sub heater driving time 
based on a difference between a calculated head temperature and a target head temperature. 

[0143] The 50 ms interrupt as shown in Figure 23 calculates head temperature for each head based on the amount 
of head driving pulses applied at each head. Calculations are based on pre-stored tables in ROM 122 which provide 
constants for use in calculating temperature increase as well as temperature decrease based on head firings. 
35 [0144] The 50 ms interrupt further controls pulse width modulation control in accordance with pre-stored tables in 
ROM 122 so as to set the pre-heat pulse for each print nozzle as well the actual main pulse width for each nozzle. The 
pulse parameters are then sent to control logic 1 24. 

[0145] The 50 ms interrupt further effects head protect control so as to ensure that the width of the pre-heat pulse 
and the width of the main pulse are not in excess of limits that might damage the print head. 
40 [0146] As shown in Figure 23, the 500 ms interrupt effects main heating control. As also shown in Rgure 23, the 1 
sec. interrupt calculates environmental temperature, and then proceeds to update target temperatures k^sed on the 
calculated environmental temperature. 

[0147] It should be noted that each of the 10ms, 50ms, 500ms, and 1 sec. durations are merely illustrative and may 
be altered. 

45 

3.6 Commands To And From The Host Processor 

[0148] The following summarizes tiie commands sent to and from host processor 23 over bi-directional printer Inter- 
face 104. Generally speaking, each command will include one or more parameters, with some commands (such as the 

50 [DATA] image data ti-ansmission command) also including data. 

[0149] The status request command [STATUS] is a generalized command that elicits a response over bi-directional 
intertece 104 from printer 30. Through use of the status request command, host processor 23 can obtain detailed infor- 
mation concerning printer 30, such as the contents of EEPROM 132, alignment and density sensor results, and the like. 
The status request command is therefore discussed in considerat^e detail below. 

55 [0150] In the sections below, a mnemonic for each command Is shown enclosed by square brackets ("Q"). The mne- 
monics shown below are simply examples. The actual sequence and combinations of letters used to form the command 
mnemonics is immaterial, so long as usage is consistent in the printer side and the host processor side such that com- 
mands sent by one are understandable to the other. 
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3.6.1 Control Commands 



[0151] Control commands serve to control print operations of printer 30. The following is a description of the various 
control commands. 

5 

[LOAD] - Paper Load 

[01 52] The load command causes paper loading, but does not eject the recording medium currently loaded. This com- 
mand must be sent to printer 30 even when a medium is already loaded manually. 

10 

[EJECT] - Paper Eject 

[0153] . This command prints all data remaining in the print buffer, then ejects the medium currently loaded. 

IS [PRINT] - Print Execution 

[0154] The Print Execution command causes the data in the print buffer to be printed on a currently ^loaded recording 
medium. The printing area extends from the left edge to the right edge of each print buffer specified t>y the Left and 
Right parameters of the [EDGE] command described below. 

[CARRIAGE] - Carriage Movement 

[0155] The Canlage Movement command includes a Position parameter which specifies carriage position in units of 
column position. This command is used for forward and reverse seeking. 

25 

[SKIP] - Raster Skip 

[01 56] The Raster Skip command is used to advance the vertical print position by the number of raster lines specified 
by a Skip parameter. 

30 

[DATA] - Image Data Transmission 

[0157] This command is used to transmit bit image data of yellow (Y), magenta (M), cyan (C) or black (Bk or K) to 
printer 30 individually in column image format. Multiple sequences of this command may be issued to make a single 
35 scan line. Bit image data is stored into the area specified by the block [BLOCK] and color [COLOR] commands . 
described below. Printer 30 will actually start printing when the [PRINT] command is received. 

3.6.2 Setting Commands 

40 [0158] Setting commands specify settings for print operations performed by printer 30. Once these commands are 
set. they are valid until the settings are changed by another command. If no settings are provided for a page, the set- 
. tings will be reset to default settings. Setting commands are described in more detail below: 

[RESET] - Printer Reset 

45 

[0159] The Mode parameter defines the Printer Reset command and specifies the reset mode. Default settings are 
included for data compression flag, buffer size, droplet size, print speed, pulse control tables. buffer control tables, and 
the like. 

so [COMPRESS] - Select Data Compression 

[0160] The Mode parameter of the Select Data Compression command specifies whether the image data is com- 
pressed or un-compressed. with un-compressed being the default setting. 

55 [DEFINE_BUF] - Define Print Buffer 

[0161] The Define Print Buffer command is used to define the memory size and configuration of print txiffer 139, for 
each of heads A and B in common. 
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[DROP] - Select Droplet Size 

[0162] This command is used to specify the ink droplet size (large or small) for each print head. 
5 [SPEED] - Select Print Speed 

[0163] This command is used to specify the printing speed. 
[DIRECTION] - Set Print Direction 

10 

[0164] The Direction parameter of this command specifies whether printing will be in the forward direction (left to right) 
or the backward direction (right to left). 

[EDGE] - Set Print Edge 

IS 

[01 65] The Set Print Edge command specifies the left edge and the right edge of print position in units of column posi- 
tion: the left edge must be smaller than the right edge: 

[BLOCK] - Select Print Block 

20 

[0166] This command is used to specify the left edge and the right edge of a data block in units of column position 
from the top of each print buffer. The [BLOCK] command also specifies where bit Images following a [DATA] command 
(described above) are stored. 

25 [COLOR] - Select Print Color 

[01 67] This command is used to specify the location, corresponding to color, in print buffer 1 39 where bit images data 
following a [DATA] command (described above) are stored. . 

30 [DEFINE.PULSE]- Define Heat Pulse Table 

[0168] The [DEFINE__PULSE] command is used to define up to plural different heat pulse block tables. The pulse 
block table must be defined before printer 30 receives the [SELECT_PULSE] command which will be defined below 

35 [SELECT_PULSE] - Select Heat Pulse Table 

[0169] The Select Heat Pulse Table command is used to select one heat pulse block table, from among plural tables 
defined by the [DEFINE_PULSE] command above, that is in common with all heads. 

40 [DEFINE_CONTROL]- Define Buffer Control Table 

[0170] This command is used to define up to plural different print buffer control tables. The print buffer control table 
must be defined before the printer receives [SELECT_(X)NTROL] command (described below). 

45 [SELECT_CONTROL] Select Buffer Control Table 

[0171] This command is used to select a print buffer control table for each print head 130a and 130b, from among the 
plural tables defined in the [DEFINE_CONTROL] command. 

50 3.6.3 Maintenance Commands 

[0172] Maintenance commands serve to maintain print operations of printer 30 and are described in more detail 
below. 

55 [RECOVER]- Head Recover 

[0173] Receiving this command causes printer 30 to go into head recovery mode, such as cleaning and ink suction 
operations. 
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[PGR] - Change Pulse Control Ratio 

[0174] This command is used to change a ratio of the Pulse Control Table. Each ratio can be set from 1 through 200, 
which means 1% through 200%. Default setting is 100 which means 100%. 

5 

[UCTJ - Universal Coordinated Time 

f 

[0175] This command is used to set the current time in printer 30. and must be sent to printer 30 at the onset of a print 
job start. Printer 30 uses the time to determine whether or not printer 30 should recover the print head. The time value 
10 Is expressed as the number of seconds elapsed since midnight (00:00:00), January 1. 1970, Universal Coordinated 
Time (UCT), according to the system clock of host processor 23. 

[SCAN] - Scan Sensor 

15 [0176] This command Is used to read an auto-alignment sensor value and to send the result back to host processor 
23. Scanning speed, direction, resolution and area are defined by the [SPEED], [DIRECTION], [DEFINE_BUF] and 
[EDGE] commands, respectively, as described above. . 

[NVRAM] - NV-RAM Control 

20 

[0177] This command Is used to read data from EEPROM 132 and send the read data back to host processor 23. 
[STATUS] - Status Request 

25 [01 78] This command is used as a prefix command to send status requests to printer 30. Requests can be made for 
basic settings, main status, and detailed status. 

[0179] Basic Setting Commands are commands used by host processor 23 to set printer 30 and do not necessarily 
require a response from printer 30. 

[0180] Main Status Request/Response commands are commands which are used to obtain status information in reg- 
30 ular mode and include Base Status [BASE_STATUS], Echo Conhmand [ECHO], print head configuration [HEAD], Align- 
ment Sensor Results [SENSOR_RESULTS]. EEPROM data sending to host [DATA_SEND], and Shift Buffer Size 
sending to host [BUFFER_SIZE]. For each Main Status Request/Response command issued, a response is automati- 
cally returned to host processor 23. 

[0181] Detailed Status Request/Response commands are used to obtain detailed status information. These com- 
35 mands include Detailed Job Status [JOB_STATUS]. Detailed Busy Status [BUSY_STATUS]. Detailed Warning Status 
[WARNING_STATUS], Detailed Operator Call Status [OPERATOR_CALL], and Detailed Service Call Status 
[SERVICE_CALL]. Like Main Status Request/Response conrimands, for each Detailed Status Request/Response com- 
mand issued, a response is automatically returned to host processor 23. 

40 3.7 Commands To And From The Printer Engine . 

[0182] Host processor 23 and printer 30 send commands to printer engine 131 through insertion of messages into 
mailbox 219 (see Figure 22). The messages are processed by engine tasks 206. 

45 4.0 Paper Ejection Tray 

[0183] In fc>rief. this aspect of the present invention is an ejection tray for use with the printer described herein. Struc- 
turally, the printer includes a housing defining a media feed portion and a media eject port where the housing is 
adapted to house a print engine for printing onto recording media. The ejection tray includes a base slidably receivatDle 

so in the printer's housing at a position laterally distanced from the media eject port. The base includes at least a pair of 
recesses extending in a sliding direction of the base. A pair of flaps are also included in the ejection tray. The pair of 
flaps each have at least one width portion corresponding to the lateral distance between the base and the eject port: 
Each flap is hinged Into a corresponding recess of the base, and Is biased In an upward direction via a spring which 
provides for angular motion of the flap relative to the base. Upon sliding action of the base out of the housing, the flaps 

55 are biased upward out of the recesses to a height con-esponding to the position of the media eject port. 

[0184] As described in more detail below, the foregoing configuration provides for easy set-up and storage of the 
paper ejection tray. In Edition, the foregoing configuration reduces the chances that paper ejected from the printer will 
block the printer's ejection area. 
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4.1 Rrst Embodiment 

[0185] Figure 24 shows a perspective view of printer 30 with paper ejection tray 41 set up for use. At this point it should 
be noted that although the paper ejection tray of the present invention will be described with respect to printer 30 shown 

5 in Figures 1 and 24, the paper ejection tray of the present invention can be used to receive paper or other types of 
recording media ejected from any type of apparatus (e.g,. a facsimile machine, etc.). In this regard, for ease of descrip- 
tion the invention will be described with respect to paper, as opposed to other types of recording media. 
[0186] Rgure 25 shows a detailed perspective view of paper ejection tray 41 . As shown in the f igures» paper ejection 
tray 41 Includes base 240. two flaps 241 a and 241 b, springs 242a and 242b, and tray extension 244. Each of flaps 241 a 

10 and 241b is hinged at one edge to one of recesses 264a and 264b of base 240. as described in more detail below. Addi- 
tionally, each of flaps 241a and 241b is biased is an upward direction relative to base 240 via springs 242a and 242b, 
respectively Addrtionally, springs 242a and 242b provide for controlled upward and downward angular motion of flaps 
241a and 241b relative to base 240. 

[0187] Figure 26 shows a doseup side view of the connection of flap 241b to base 240. In this regard, both of flaps 
IS 241 a and 241 b are hinged to base 240 in the same manner. Accordingly, only the connection of flap 241 b is described 
here. Specifically, flap 241b is hinged via dowels 246 and 247 which are disposed at each end thereof, and which fit into 
corresponding receiving holes (not shown) in recess 264b of base 240. These dowels form an axis about which flap 
24 1 b rotates angularly relative to base 240. 

[0188] Also included on flap 241b is center rod 248, shown in Figure 26. Spring 242b is wound around center rod 248 

20 and connected to both flap 241b and base 240. Inherent tension in spring 242b biases flap 241b in an upward direction 
out of recess 264b when paper ejection tray 41 is outside of housing 31. Thus, flap 241b is at an initial angle relative to 
base 240 when no downward force is applied to flap 241b. Examples of this initial angle, labelled 249a and 249b, are 
shown in Figure 24. In preferred embodiments of the invention, the initial angle is less than 90**. 
[0189] When downward pressure is applied to flaps 241a and 241b, springs 242a and 242b are compressed. How- 

25 ever, springs 242a and 242b prevent flaps 241a and 241b from contacting base 240 at least until a predetermined 
amount of pressure is applied to flaps 241a and 241b. Thus, when pressure is applied to flaps 241a and 241b. flaps 
241a and 241b move angularly downward towards base 240. but do so in a controlled manner. During this motion, the 
angle between each of flaps 241 a and 241 b and base 240 decreases from the initial angle, eventually down to 0? if the 
pressure is sufficiently great In this regard, the amount of pressure required to move each of flaps 241 a and 241 b down 

30 to 0** is based on the tension of a conesponding one of springs 242a arxi 242b. 

[0190] Preferably, each of flaps 241a and 241b has a width portion which roughly corresponds to a lateral distande 
between base 240 and media eject port 40. To illustrate this. Figure 27 shows flaps 241a and 241b flat against basie - 
240. Specifically, as shown in Figure 27. flap 241a includes four edges, namely top edge 250 which supports paper 
ejected from printer 30. bottom edge 251 which connects to base 240, and side edges 254 and 252 (i:e.. the width pOr- 

35 tion noted above), respectively. 

[0191] Preferably, the edge of each flap which faces printer 30. i.a. side edge 252 for flap 241a and side edge 252b 
for flap 241b, is beveled (e.g.. tapered) and is angled away from printer 30 as shown in Figure 25. More specifically, 
because edges 252 and 252b are beveled, when these edges contact housing 31 of printer 30. the edges slide relative 
to housing 31 causing flaps 241a and 241b to fold. Eventually, flaps 241a and 241b fold enough so that the lateral push- 

40 Ing forces printer 30 and into tray receptacle 42. This feature is described in more detail below. 

[0192] Figure 25A shows a close-up view of edge 252b of flap 241b. As noted above, and as shown in Figure 25A, 
edge 252b is beveled, meaning that it is angled relative to top edge 250b and to base 240. Rgures 25B and 25C illus- 
trate this feature even further. In this regard. Figure 25B shows a clbse-up side view of flap 241b. Figure 25C shows a 
view, taken from position A-A, of a cross section of flap 241b taken along dashed line 63. Thus, as depicted in Rgure 

45 25C, beveled edge 252b is angled relative to top edge 250b and base 240. This angle is labelled 255 in Figure 25C and, 
in preferred embodiments of the invention, is roughly 45**. 

[01 93] Thus, when ejection tray 41 is pushed towards printer 30, as is the case during storage of tray 41 , the beveled 
edges of flaps 141a and 141b contact housing 31 of printer 30, in particular exterior edge 272. In response to this con- 
tact, and as additional lateral pushing force is applied, contact between exterior edge 272 and the beveled edges force 
50 flaps 241 a and 241 b downwards toward the recesses in base 240. If enough force is applied, flaps 241 a and 241b are 
forced sufficierrtly downward to slide underneath exterior edge 272 and into tray receptacle 42. This feature of the inven- 
tion is described in greater detail below. 

[0194] Side edge 252 also includes portion 253 (corresponding side edge 252b includes similar portion 253b). which 
is preferably not beveled or angled. Such an arrangement provides a flat surface for engaging each of flaps 241a and 
55 241b to base 240 via dowel 246, thereby increasing structural strength at the engagement. Side edges 253 and 253b 
fit underneath exterior edge 272 and thus do not adversely affect storage of ejection tray 41 into receptacle 42. 
[0195] With regard to side edge 254. that edge is neither angled nor beveled in the example shown. However, side 
edge 254 may be angled and beveled if desired so as to facilitate pulling of paper ejection tray 41 from printer 30. 
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[01 96] With regard to top edge 250 and bottom edge 251 . these edges preferably are not parallel to each other so as 
to reduce the chances that ejected paper will bend. That Is, In preferred embodiments of the invention, top edge 250 is 
angled slightly upwards relative to bottom edge 251. and base 240 so as to facilitate downward movement of ejected 
paper. Thus, a distance between top edge 250 and bottom edge 251 Is at a minimum at intersection point 260 between 
5 side edge 252 (the beveled edge) and top edge 250. This distance increases farther away from intersection point 260 
such that the distance is at a maximum at intersection point 261 , i.e., the point where side edge 254 intersects top edge 
250. This angled construction of top edge 250 relative to bottom edge 251 reduces the chances that paper will fall off 
of flaps 241 a and 241 b during ejection. 

[0197] As noted above, base 240 also includes recesses 264a and 264b (see Figures 24 and 25), which correspond 
10 to respective ones of flaps 241a and 241b and which extend in a sliding direction of base 240. In preferred embodi- 
ments, each of recesses 264a and 264b has a shape which con^esponds to a shape of a respective one of flaps 241a 
and 241 b. By virtue of this configuration, when the angle between a flap, such as flap 241 a, and base 240 is roughly 0"*, 
the flap can fit almost entirely within its corresponding recess. When both flaps are fitted thusly, top surface 266 of base 
240. including flaps 241a and 241b. is substantially planar, as shown in Figure 27. This facilitates sliding of paper ejec- 
ts tion tray 41 into receptacle 42. a described below. 

[0198] More specifically, as noted above, printer 30 includes tray receptacle 42 (see Figure 24) which stores paper 
ejection tray 41 when printer 30 is not in use. Figure 28 is an underside view of printer 30, which shows tray receptacle 
.42. As shown, tray receptacle 42 preferably comprises a slot or the like on the underside of printer 30, into which paper 
ejection tray 41 (including tray extension 244) fits. When flaps 241a and 241b are at 0**. or substantially close to 0**, rel- 
20 ative to base 240, paper ejection tray 41 can slide within tray receptacle 42. In this regard. Figure 1 shows a frorrt view 
of paper ejection tray 41 stored within printer 30. 

[0199] Paper ejection tray 41 also may include tray extension 244 noted above. As shown in Rgure 24. tray extension 
244 preferably slides into and out of a slot within base 240. This facilitates storage of paper ejection tray 41 within printer 
30. Additionally, tray extension 244 includes manual stop 269. Manual stop 269 Is used to slide tray extension 244 into 

25 or out of the slot in ejection tray 41 and to keep ejected sheets of paper from falling off of paper ejection tray 41 . 

[0200] In addition, manual stop 269 can be helpful in setting up and storing paper ejection tray 41 . That is, as shown 
in Figure 1 , when paper ejection tray 41 is stored within tray receptacle 42, manual stop 269 does not fit entirely within 
tray receptacle 42 and therefore remains accessible to a user. By grasping manual stop 269 arKi pullingmanual stop 
269 away from printer 30. the user is able to set paper ejection tray 41 up for operation. Conversely, by pushing on nnan- 

30 ual stop 269 towards printer 30, the user can store, paper ejection tiray 41 within printer 30. These operations are 
described in greater detail below. . . • . 

[0201] In this regard. Figures 29A to 29D shovir the operation of paper ejection tray 41 during use. Reference is also 
made to Figures 2 and 24 to describe setup and storage of paper ejection tray 41 . To begin, Figure 1 shows printer 30 
when not in use. In this conf iguration, paper ejection tray 41, is stored within receptacle 42. It is preferable to store paper 
35 ejection tray 41 when printer 30 is hot in use. since storage reduces the chances that paper ejection tray 41 will be Inad- . 
vertentiy damaged. 

[0202] To set up paper ejection tray 41 , a user simply pulls paper ejection tray 41 out of printer 30, thereby causing 
paper ejection tray 41 to slide out of receptacle 42 in housing 31 . This is typically done by pulling on manual stop 269; 
although pulling on other portions of paper ejection tray 41 will accomplish tiie same result. During this pulling action. 

40 flaps 241 a and 241 b remain relatively flat against base 240 until flaps 241 a and 241 b are freed from tray receptacle 42. 
[0203] Once flaps 241a and 241b are freed from tray receptacle 42, flaps 241a and 241b are biased upward out of 
recesses 264a and 264b, respectively, to a height corresponding to the position of media eject port 40. That is, when 
flaps 241 a an6 241b are freed from tray receptaclei 42. there is no longer anything to hold flaps 241 a and 242b against 
base 240. Consequentiy. springs 242a and 242b cause flaps 241a and 241b to bias upwards so that the flaps assume 

45 a rough shape when viewed head-on. As noted above, at this point, each of flaps 241a and 241b is at an angle rel- 
ative to base 240 which is preferably less than 90''. Once flaps 241 a and 241b are in this position, printer 30 may begin 
ejecting paper onto paper ejection tray 41 . 

[0204] Figures 29A to 29D show front views of paper ejection tray 41 set up to receive paper ejected from printer 30. 
As shown in Figure 29A, angles 249a and 249b, referred to above as the initial angles, are less than 90'' relative to base 

50 240. Because angles 249a and 249b are less than 90*^. the weight of paper ejected onto flaps 241a ard 241b will cause 
the flaps to move downward, thereby decreasing angles 249a and 249b, respectively. This is shown in Figure 29B. 
[0205] More specifically, Figure 29B shows a case in which paper ejection tray 41 has received several sheets of 
paper 270 which have been ejected from printer 30. As shown, weight from paper 270 causes flaps 241a and 241b to 
move downward, toward base 240. As a consequence, angles 24ga and 249b between the flaps and the base decrease 

55 from the initial angle. Figure 29C shows a case in which even more sheets have been added to paper ejection tray 41 , 
thus forcing flaps 241a and 241b still further downward, and thus decreasing angles 249a and 249b still further. This 
action reduces the chances that sheets of paper ejected from media eject port 40 will block media eject port 40 during 
operation of printer 30. 
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[0206] Figure 29D shows a case in which still more sheets of paper have been received by flaps 241a and 241b. In 
this case, the weight of paper 270 on flaps 241 a and 241 b is suff ident to force flaps 241 a and 241 b to roughly a angle 
relative to base 240. As a result, each of flaps 241 a and 241 b will be forced into a corresporxiing one of recesses 264a 
and 264b. Thus, as compared with its conventional counterparts, printer 30 is able to print more paper without substan- 

5 tially blocking media eject port 40. 

[0207] As described above, the degree to which flaps 241 a and 241 b move downward in response to an applied force 
depends on the tension of springs 242a and 242b biasing flaps 241a and 241b relative to base 240. As noted above, 
in preferred embodiments of the invention, springs 242a and 242b have a tension such that flaps 241a and 241b are 
biased to a height of media eject port 40 when no paper is ejected thereon. In particularly preferred embodiments of 

10 the invention, the position to which paper is ejected remains relatively the same for all sheets of paper. 

[0208] Moreover, in preferred embodiments of the invention, both of flaps 241 a and 241 b have substantially the same 
shape and. as noted above, the same connections to base 240. Springs 242a and 242b in connection with both of flaps 
241a and 241b also preferably have roughly the same tension. By virtue of this symmetry, the present invention is able 
to hold more paper with fewer mechanical malfunctions. In this regard, it should also be noted that paper ejection tray 

IS 41 also operates in cases where ftaps 241a and 241b have different shapes, and springs 242a and 242b produce dif- 
ferent biases. 

[0209] Next, storage of paper ejection tray 41 within printer .30 will be described with reference to Figures 2 and 24. 
In this regard, as shown in Figure 24, receptacle 42 on printer 30 includes exterior edge 272. Additionally, each of flaps 
241a and 241b includes a side edge (i.e.. side edges 252 and 252b shown in Figures 25 and 27) which faces printer 
20 30. which is angled away from printer 30. and which is beveled, as described above with respect to Figures 25A, 25B 
and 25C, such that the side edge is substantially flat and angled relative to the top edge and base. As described below, 
these side edges, namely side edges 252 and 252b. are constructed in this manner so as to facilitate storage of paper 
ejection tray 41 within tray receptacle 42. 

[0210] More specifically, to store paper ejection tray 41 within tray receptacle 42, a user need only push laterally on 
25 base 240 (or tray extension 269). This lateral pushing forces the flaps to co-act with housing 31 so as to fold the flaps 
back into the recesses upon sliding action back into housing 31 . Specifically, the lateral pushing action forces portion 
253 underneath tray receptacle 42 and fbrces.side edges 252 and 252b against exterior edge 272 of tr^ receptacle 42. 
Exterior edge 272 "responds" with an equal, but opposite, force against the side edges. Because side edges 252;arici : 
252b are beveled and angled (see, ag.. Figure 25A). this equal but opposite force includes a downward component 
30 which forces flaps 241a and 241b to move downward towards base 240. As additional lateral pushing force is applied 
to ejection tray 41 , side edges 252 and. 252b slide against exterior edge 272, forcing flaps even further downward. - v ; 
[021 1 ] As was the case above, as flaps 241 a and 241 b move downward, the angles between flaps 241 a and 241 b * 
and base 240 decrease. Due to the angle of the side edge, as additional force is applied to the side edges, flaps 24Ta 
and 241b continue to slide along exterior edge 272. thus forcing flaps 241a and 241b still further downwards. Everitu- 
35 ally, if enough lateral pushing force is applied, flaps 241a and 241b are forced downward such that they fold within 
recesses 249a and 249b. Thus, paper ejection tray 41 slides easily into tray receptacle 42. Figure 1 shows paper ejec- 
tion tray 41 stored vtnthin tray receptacle 42 of printer 30. 

[0212] Accordingly, unlike its conventional counterparts, this embodiment of the preservt invention provides a means 
for storing paper ejection tray 41 which does not require significant physical manipulations by the user. Moreover, 

40 because the shape of flaps 241a and 241b and housing 31 is primarily responsible for the ease with which paper ejec- 
tion tray 41 can be stored, the number of additional mechanical components on paper ejection tray 41 is reduced. 
[021 3] At this point, it is noted that the shape of tiie holding members (e.g.. the flaps) used to hokJ the recording mate- 
rial may also vary. In this regard, the present invention also can be implemented using a single holding member of more 
than two holding members. For example, the invention can be implemented using a single **V"-shaped holding member 

45 in which one or more biasing springs are positioned between opposing arnris of the holding member. An example of a 
second embodiment of the paper ejection tray of the present invention that may be used with printer 2460 is shown in 
Figure 29E. 

4.2 Second Embodiment 

50 

[021 4] As shown in Figure 29E, paper ejection tray 2400 includes a single flap, namely flap 2410. Flap 2410 is hinged 
inside single recess 2440 and biased by a spring (not shown) reliative to recess 2440. Flap 2410 operates in a similar 
manner to the flaps described in the first embodiment above. Accordingly, a detailed description will be omitted here for 
the sake of brevity Suffice it to say that top surface 2450 of flap 241 0 co-acts with printer 2460 when tray 2400 is pushed 
55 towards printer 2460 so that flap 241 0 folds within recess 2440. This permits flap 241 0 to be stored within printer 2460. 
Likewise, when tray 2400 is withdrawn from printer 2460, a spring (not shown) underneath flap 2410 biases flap 2410 
to a height roughly equal to that of media eject port 2465 of printer 2460. 

[021 5] During printing, flap 241 0 operates in a manner similar to the flaps described above in the first embodiment. 
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Specifically, as paper is ejected onto flap 2410. flap 2410 moves downwardly toward recess 2440 and eventually, when 
enough paper has been ejected, into recess 2440. As was the case above, downward motion of flap 2410 is controlled 
via a spring (not shown) which biases flap 2410 relative to recess 2440. 

[0216] Finally, it is noted that although the paper ejection tray has been described with respect to a single flap and a 
5 pair of flaps, the invention can be used with multiple flaps as well. 

5.0 Ink Cleaning Mechanism 

[021 7] In brief, this aspect of the present invention is a cartridge receptacle which is mounted on a carriage for releas- 
10 aJtAy receiving a cartridge having a print head and at least one removable ink reservoir. The receptacle includes a piv- 
oting lever which permits removal of the at least one ink reservoir. The lever extends over at least a portion of the at 
least one ink reservoir so as to prevent access to the at least one ink reservoir until such time as the lever is pivoted 
away from the at least one ink reservoir. When the lever is pivoted away from the at least one ink reservoir, and then the 
fever is pivoted over the at least a portion of the at least one ink reservoir, a signal is output which prompts cleaning of 
15 the print head. 

[0218] As described above with respect to Figure 4. printer 30 includes cartridge receptacles 64a and 64lx Access to 
ink cartridges (and thus to ink reservoirs in those cartridges) in cartridge receptacles 64a arKi 64b is provkled automat- 
ically via access door 32 shown in Figure 2. More specifically, as noted above, printer 30 includes a sensor which 
senses when access door 32 has been opened or closed. In response to this sensor sensing that access door 32 has 
20 opened, carriage motor 66 is driven so that cartridge receptacles 64a and 64b move roughly to the center of carriage 
69. i.e.. to roughly the location shown in Figure 4. This area of printer 30 corresponds to the irrternal portion of printer 
30 which, is accessible when access door 32 is open. Thus, it is possible to access cartridge receptacles 64 merely by 
opening access door 32. The significance of this will become apparent below. 

[0219] Figures 6A and 6B. described above, show the physical construction of cartridge receptacle 64b. Figures 7A 
25 and 7B. described above, show the physical construction of ink cartridge 300b, which can be installed in cartridge 
receptacle 64b. As noted above, circuit contacts for the cartridge receptacle shown in Figures 6A and 6B and the ink 
cartridge shown in Figures 7 A and 78 are used in connection with ink cartridge cleaning. More specifically, according 
to the present invention, a circuit contact on a cartridge receptacle engages and disengages a circuit contact on an ink 
cartridge in response to opening and closing a lever of the cartridge receptacle. 
30 [0220] Front views of the cartridge receptacle shown in Figures 6A and 68 during operation are shown in Rgures 30A 
and 308. As shown in Figures 30A and 30B, cartridge receptacle 64b includes capsule 73 and lever 72, among other, 
things. Lever 72 is hinged so that it pivots relative to capsule 73. This pivoting action permits a user to access and to 
remove either an entire ink cartridge in cartridge receptacle 64b or just an ink reservoir from the cartridge. 
[0221] Lever 72 is also connected to capsule 73 so that when lever 72 is pivoted, e.g., opened or closed, capsule 73 
- 35 mQves laterally, as described in detail above with respect to Rgure 6B. More specifically, when lever 72 is pivoted from 
the open position shown in Rgure 308 to the closed position as shown in Rgure 30A, capsule 73 m6ves laterally within, 
cartridge receptacle 64b iri the direction of arrow 280 (see Rgure 30A). This movement causes side wall 75 of capsule 
73 to come into contact with side wall 78 of cartridge receptacle 64b. On the other hand, when lever 72 is moved from 
the closed position shown in Figure 30A to the open position shown in Rgure 308. capsule 73 moves laterally within 
40 cartridge receptacle 64b in the direction of arrow 281 (see Figure 308). This movement causes side wall 75 of capsule 
73 to move away frorn side wall 78 of cartridge receptacle 64b. 

[0222] During the motion described above, namely the movement of capsule 73.between the position shown in Figure 
30A and the position shown in Rgure 308. finger 282 on capsule 73 slidably engages sleeve 284. As also shown in Fig- 
ures 30A and 308. capsule 73 includes shoulders 286, and lever 72 includes flanges 287. Thus, when lever 72 is 

45 closed, as shown in Figure 30A, flanges 287 contact shoulders 286. and not an installed ink cartridge or Ink reservoir. 
By virtue of these features, cartridge movement caused by inadvertent contact with lever 72 can be reduced. 
[0223] Rgures 31 A and 318 show views of cartridge receptacle 64b with ink cartridge 300b installed therein. As 
shown in Figure 31 A. when lever 72 is pivoted over a portion of ink reservoirs 83, i.e., lever 72 is in the closed position, 
an operator is prevented from accessing ink reservoirs 83. That is. in this position, the tops of ink reservoirs 83 are cov- 

50 ered, at least in part, by lever 72, thereby restricting access thereto. In addition, in this position, cartridge circuit contact 
81 on ink cartridge 300b engages device circuit contact 71 on cartridge receptacle 64b. In contrast, when lever 72 is 
pivoted away from ink reservoirs 83. i.e.. lever 72 is in the open position, an operator can access ink reservoirs 83. In 
this position, cartridge circuit contact 81 on ink cartridge 300b is disengaged from device circuit contact 71 on cartridge 
receptacle 64b. 

55 [0224] Thus, during the lateral motion of capsule 64b described above with respect to Figures 30A and 308. circuit 
contacts 71 and 81 engage and disengage. Specifically, circuit contacts 71 and 81 disengage when lever 72 is opened, 
and engage when lever 72 is closed. This engaging and disengaging of circuit contacts is the means by which a user 
designates print head 300b for cleaning, and causes a signal to be output which prompts cleaning of print head 300b. 
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A controller (such as CPU 121 described above) in printer 30 receives this signal and initiates the cleaning process 
described below. 

[0225] In this regard, it is noted that either one of both of the ink cartridges in printer 30 can be designated for cleaning 
In the foregoing manner. It is furtheb noted that Ink cleaning Is performed only for the cartridge or cartridge's that have 

5 been designated in this manner 

[0226] Once an ink cartridge has been designated, ink cleaning does not actually take place until access door 32 is 
closed. That is, during ink cartridge designation, access door 32 must be open. Ink cleaning will not take place until the 
access door sensor noted above senses that access door 32 is closed. In this regard, once it is sensed that access door 
32 is closed, cartridge receptacles 64a and 64b move automatically to home location 87. i.e.. the position correspond- 

10 ing to ink cleaning mechanism 86. Ink cleaning mechanism 86 is then used to clean (i.e.. suction) ink from the print head 
of a designated cartridge. 

[0227] To this end, ink cleaning mechanism 86 includes two print head connection caps 88a and 88b (see Figure 4). 
Each of these print head connection caps corresponds to a print head of an ink cartridge in one of cartridge receptacles 
64a and 64b, respectively. However, only one of print head connection caps, namely cap 88a, is connected to a rotary 
IS pump which cleans (i.e.. suction) ink from print heads. An exanrple of this configuration is shown in Rgure 32. in which 
print head connection cap 88a is connected to pump 294. 

[0228] Thus, when access door 32 is closed, the print head of the ink cartridge which has been designated for clean- 
ing connects with print head connection cap 88a. For example, as shown in the block diagram of Figure 33A. if ink car- 
tridge 300b has been designated for cleaning, ink cartridge 300b is moved into contact with cap 88a. On the other hand, 

20 if ink cartridge 300a has been designated for cleaning. Ink cartridge 300a Is moved into contact with cap 88a when 
access door 32 is closed, as shown in the block diagram depicted in Figure 33B. In the case that both ink cartridges 
have been designated for deanirig in the manner set forth above, the ink cartridges connect with cap 88a in sequence. 
[0229] Once connection is sensed via the home location sensor noted above, ink is extracted (i.e.. suctioned) by pump 
294 from nozzles or holes In the print head of the cartridge. Following this cleaning operation, the cartridge may then 

25 be used for printing. 

6.0 Storing Printer Prof ile Parameters ■ 



[0230] In brief, this aspect of the invention is a method for controlling a print head of an image printing device having 
30 at least one print head. The method includes the steps of obtaining profile information of the at least one print head, 
storing the profile parameters in a non-volatile RAM, outputtlng. upon request, the profile Information to a host proces- 
sor connected to the image printing device, wherein the host processor utilizes the print head profile information to pro- 
duce compensation parameters which compensate print information to be sent from the host processor to the print 
head for printing. 

35 [0231 ] In detail, when applying power and performing a hard power-on, printer 30 enters an offline mode. In this mode. 
CPU 121 in printer 30 retrieves from ROM 122 Initialization software and executes a power-on self-test program 
(POST). Among many of the self-tests and status-checking programs that It performs, CPU 121 checks the status of 
print head 130a and print head 130b to determine whether either or both print heads have been Installed in printer 30. 
One way in which CPU 121 checks this status is by determining whether access door 32 has been opened and, if so, 

40 comparing print head identification (ID) information stored in EEPROM 1 32 with a current print head's ID. If a new print 
head has been installed, this change will be noted in EEPROM 132 with other stored printer profile parameters, as dis- 
cussed below. 

[0232] However, at an initial installation and power-on, CPU 121 gathers various profile jsarameters regarding printer 
30 as part of its Installation programming. For example, CPU 121 will obtain the printer ID. print head ID information (or, 
45 if more than one print head is Installed, then printer IDs for all print heads), as well as the current status of printer 30 
and print head 130a arxJ 130b (this feature is also performed after any subsequent power-on as well as at specific pre- 
determined times and events, which will be discussed in greater detail below). 

[0233] Once POST processing has been performed, printer 30 enters an online mode and awaits commands from 
host processor 23. As shown in Figure 10, host processor 23 sends commands through printer Interface 104 directly t o 
50 control logic 124 of printer 30. C ommands from host processor 23 to readyWrite to EEPROM 132 of printer 30 are al^o 
directed through printer interface 104 ana c ontrol logic 1 24^ ~ 

[0234] Typically, after going online, host processor -£6 will send a status request command [STATUS] to printer 30 via 
control logic 124. Upon receiving such a status request command. CPU 121 of printer 30 will send stored printer profile 
parameters from EEPROM 132. I/O ports unit 127. and control logic 124 to host processor 23. An example of printer 
55 profile parameters which are stored in a specific area in EEPROM 132 and registered with host processor 23 are shown 
below in Table 1. 
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Table 1 

CONTENTS OF EEPROM 
^ Waste Ink Amount 

Print Head Change Count 

Driver's Information 
1Q Print Head Clean Time 

Print Head Changed 

[0235] These foregoing printer profile parameters are used by host processor 23 to compensate prirrt head command 

15 data during a print operation. 

[0236] Thus, with reference to the flow diagram shown in Figure 341 in step S3401. upon performing a hard power- 
on, printer 30 enters an offline mode. During this offline mode, in step S3402 printer 30 performs a POST operation so 
as to gather status and functional data, and to check for any -hardware or software faults. After initialization, in step 
S3403, CPU 121 of printer 30 determines if a new print head has been installed, in the case tiiat step S3403 is encoun- 

20 tered during the initial power-on after installing printer 30 and one or more ink cartridges having one or more print 
heads, respectively, have been installed, CPU 121 obtains irrformation from the newly-inserted print heads and stores 
that information in EEPROM 132 and commands a cleaning process at a next soft power-on. However, if printer 30. is 
only offline because a user has opened access door 32 and has installed a new print head, in step S3404 CPU 1 21 will 
gather the print head ID and set a flag in EEPROM 132, which indicates that the prirrt head has been changed. This 

25 flag instructs host processor 23 that an ink cartridge has been changed. This process will be performed when a print 
head has been installed for the very first time as well as when a print head has been subsequently changed. 
[0237] In this regard, EEPROM 132 stores a plurality of printer profile parameters which are registered with host proc- •■ 
essor 23 for various purposes, such as for providing compensation parameters to host processor 23 which are in turn 
used to compensate for physical characteristics of both a print head and ink within a prirrt head cartridge. For exarrple, 

30 as shown in Table 2 below, EEPROM 132 stores, in addition to print head alignment and opti cal de nsity informatio n, 
inform ation and parameters relating to a waste ink amount, print head change count, prin t head cleaning times, print 
head tu, print head type, etc. \ ■ . -. ■ . - 



Table 2 



Contents 


Note 


Driver's Information 


The Printer Driver reads/writes alignment data, etc. 


1 Check Sum 


The check sum of this data block 


Cleaned Time for RIGHT Head (A_Head) 


The last cleaned time for the RIGHT head (A_Head) 


Cleaned Time for LEFT Head {B_Head) 


The last cleaned time for the LEFT head (B_Head) 


Checksum 


The check sum of this data block 


Print head changed 


The status whether print head changed or not 


Cleaned Time for RIGHT Head (A_Head) [Mirror] 


Backup for recovering in System Master 


Cleaned Time for LEFT Head (B„Head) [MirrorJ 


Backup for recovering in System Master 


Check Sum 


The check sum of this data block 



[0238] Returning to Figure 34, if a new ink cartridge has not been installed, in step S3405 printer 30 enters an online 
mode in which prirrter 30 is capable of communicating with host processor 23. or if networked, with a host server. 
[0239] Once online, printer 30 waits to receive commands from host processor 23. These commands, some off which 
55 have been listed previously, are typical of the commands which can be sent to printer 30 once printer 30 is online. In 
this regard, normally, after going online, host processor 23 will output a status request [STATUS] command to printer 30 
in order to obtain any new information or parameters which may have changed while the printer vyas offline. In 
response, in step S3406 printer 30 will transmit printer profile parameters stored in EEPROM 1 32 to host processor 23. 
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Upon receiving the parameters, host processor 23 will review the parameters, in particular, the parameters dealing with 
the print heads, to determine if a print head has been changed. If it is determined that a print head has been changed, 
in step S3407 host processor 23 will determine if a test pattern should be requested. Normally, a test pattern will be 
printed so that print head alignment and optical density of the printed image can be measured. If a print head has been 
5 changed and a test pattern is required, in step S3408 host processor 23 transmits one or more commands through 
printer interlace 104 and control logic 124 to print engine 131. For example, host processor 23 can transmit a series of 
commands, as shown in Table 3 below. These commands can be transmitted together with print data to print engine 
131 so as to print a test pattern to be scanned- 



10 




Table 3 




EXAMPLE OF TEST PATTERN AND SCAN COMMAND FLOW 




The sample comniand flow in case of BC-21 x 2. Color Mode. 360dpi and 8.5** of print buffer 139 is 


is 


described below: 






[UGT] 


Universal coordinated Time. (Set Current Time) 




[RESET] 


Printer Reset (Softvyare Reset) 




[COMPRESS] 


Select Data Compression (Byte Packing Mode) . 


on 


[DEFINE_BUF] 


Define Print Buffer A (360dpi, 1 2bytes * 3.060 columns, :..) 




[DEFINE_BUF] 


Define Print Buffer B (360c4?i, 12bytes x 3.060 columns. ...) 




[DEFINE_PULSE] 


Define Heat Pulse Table (16 partition) 


2S 


[DEFINE_CdNTROL] 


Define Buffer Control Table (BC-21 Color Mode) 




[LOAD] 


Paper Load (Letter size of Plain Paper. 8.5inch x 1 1 inch) 




[SKIP] 


Raster Skip to the print position for the 1st scan 




[DIRECTION] 


Set Print Direction for the 1st scan 


30 


[EDGE] 


Set Left and Right Edge of Head A for the I st scan 




[EDGE] 


Set Left and Right Edge of Head B for the 1 st scan 




Loop 1 : 


Begin Repeat until [EJECT] commarxi 


35 


[SPEED] 


Select Print Speed for the 1§t. scan (6.51 Khz) 




[DROP] 


Select Droplet Size of Head A for the 1st scan 






QaIa^^ r^ror>lQt ^170 Off Uosir^ R fr»r 1 ct coon 




[SELECT_PULSE1 


Select Heat Pulse Table to next scan 


40 


[SELECT_C0NTR0L] 


Select Buffer Control Table of Head' A for the 1 st scan 




[SELECT_CONTROLl 


Select Buffer Control Table of Head B for the 1st scan 




Loop 2: Begin 


Repeat 18 times for 9 Block (4.5inch/0.5 inch) x 2 Head (Head A and Head B). 


45 


[BLOCK] 


Select Print Block 




Loop 3: Begin 


Repeat 4 times for 4 Color (Yellow. Magenta, Cyan. Black) 




[COLOR] 


Select Print Color 


50 


[DATA] 


image Data Transmission (540byteyblock) 


Loop 3: End 
Loop 2: End 






[DIRECTION] 


Set Print Direction for the 2nd scan 


55 


[EDGE] 


Set Left and Right Edge of Head A for the 2nd scan 




[EDGE] 


Set Left and Right Edge of Head B for the 2nd scan 




[PRINT] 


Print Execution for the 1 st scan 
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Table 3 (continued) 





EXAMPLE OF TEST PATTERN AND SCAN COMMAND FLOW 




[SKIP] 


Raster Skip to the print position for the 2nd scan (24 raster) 


5 


[SCAN] 


Scan Test Pattern and Store Data in RAM 




[SENSOR_RESULTSl 


Transmit Scanning Results 




[NVRAM] 


Write compensation parameters into EEPROM 


10 


[EJECT] 


Paper Eject (Eject Only) 



[0240] Once the test pattern has been printed, in step 83409 host processor 23 outputs a scan [SCAN] command to 
printer 30 which initiates a scan of the printed test pattern by sensors 82 on print heads 130a and 130b. Specifically, 
upon receiving the [SCAN] command, each print head 1 30a and 130b will return to home location 87 at which time cov- 
75 ers of each sensor 82 are uncapped and a sheet of paper on which a test pattern is printed is advanced so as to align 
the printed test pattern with sensors 82. . . * 

[0241] Each sensor 82 scans a portion of the printed test pattern which has been printed by its corresponding print 
head, and stores the resulting test pattern data (e.g.; alignment measurements) in RAM 129. This test pattern data is 
8-bit digitized data obtained from analog-to-digital conversion of the output voltage level of sensor 82. 

20 [0242] The test pattern data stored in RAM 129 remains there until host processor 23 sends a status request 
[SENSOR_RESULTS] command to printer 30; Upon receiving the [SENSOR_RESULTS] command, in step S3410 
printer 30 transmits the test pattern data stored in RAM 129 to host processor 23. When the data is received, host proc- 
essor 23 retrieves compensation equations from disk 25 and uses the equations with the received data in order to 
derive conrpensation parameters. Once the compensation parameters are computed, host processor 23 sends a 

25 [NVRAM] control command to printer 30 which causes printer 30 to write the compensation parameters into EEPROM 
132instepS3411. 

[0243] As stated previously, EEPROM 132 stores separate parameters and measurements for each print head 130a 
and 130b arxj compensation parameters are separately computed and downloaded based on each print heads* align-, 
ment and optical density. An example of the type of compensation parameters downloaded by host processor 23 is 
30 shown in Table 4 below. 

Table4 
Contents 

35 . 

Printer Id.. .. 
Head Id (Head A) 
Status (Head A) 

40 . X-AIign (Head A) 

Y-Align (Head A) ~ 
Frd-Align (Head A) 
Rev-Align (Head A) 

45 

Fwd_Optical Density (Head A) 

Bwd_Optical Density (Head A) 

Head Id (Head B) 

50 Status (Head B) 

X-Align (Head B) 

Y-Align (Head B) 

Frd-Align (Head B) 

55 \ 

Rev-Align (Head B) 
Fwd_Optical Density (Head B) 
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Table 4 (continued) 
Contents 
Bwd_Optical Density (Head B) 
Reserved 



[0244] The information and parameters shown above relate to alignment of print heads 130a and 1 30b as well as the 
optical density of an image printed by each print head 130a and 130b. This information is utilized by host processor 23 
10 when sending print head command signals to print heads 130a and 130b during a print operation. 

[0245] Returning to the flow diagram in Figure 34. in step S341 1 , printer 30 awaits further commands from host proc- 
essor 23. 

[0246] In step S3413. host processor 23 sends a status request [DATA_SEND] command to printer 30 and printer 
profile parameters are again registered with host processor 23. The [STATUS] commands may be sent to printer 30 at 
IS specif ic time intervals or after a specific printer event such as replacing a print head. Next, in step S341 4 host processor 
23 utilizes the printer profile parameters in order to compensate for physical characteristics and variations in each of 
print heads 130a arxi 130b as well as the inks in ink cartridges attached to each print head 130a and 130b when send- 
ing print information to each of print heads 1 30a arvJ 1 30b. 

[0247] Therefore, printer 30 memorizes a profile individually or separately from host processor 23. That makes it pos- 
20 sible for another host processor to read the registered profile from printer 30 in order to conpensate for physical char- 
acteristics related to printer 30. 

7.0 Scheduling Cleaning Of Print Heads 

25 [0248] In brief, one aspect of the invention disclosed in this embodiment is an ink jet printer which includes an inter- 
face for interfacing with a host processor and for receiving print data, print commands, and real time/date information 
from the host processor, a memory for storing the print data, print commands and real time/date information, a print 
engine for printing an image in accordance with the print data and print commands, the print engine controlling at least 
one print head to print the image, and a processor for controlling processing events of the print engine based on the 

30 real time/date information received via the interface from the host processor and based on printer-related events. 

[0249] More specifically, since print head nozzles clog due to bubbles or dry ink being trapped therein, print heads.. 
130a and 130b of printer 30 must be cleaned. The cleaning process consists of moving a print head to its home location 
where rotary pump 294 suction ink from the print head. Resulting waste ink is deposited into a waste storage area, such . 
as a waste well, where the waste ink eventually evaporates over time. It is important to clean print heads 1 30a and 1 30b 

35 after a predetermined time, which in the present invention has been determined to be an elapse of seventy-three (73) 
hours since a last cleaning. If this is not done, print head nozzles may clog, thereby adversely affecting print quality. In 
addition, in order to ensure proper operation of ink jet printer 30. each print head 130a and 130b is cleaned at ink car- 
tridge installation and each time an ink cartridge is replaced. 

[0250] As discussed previously, with the exception, of event-scheduled cleaning, printer 30 performs a print head 
40 cleaning based on an elapsed time. The elapsed time is calculated by determining how much time has elapsed since a 
last cleaning. An example of manual initiation of a cleaning operation is described above in section 5.0. The determina- 
tion of elapsed time is based on a real-time/date stamp which is downloaded from host processor 23 at the Iseginning 
of every print job. In this manner, printer 30 will be able to keep track of how much time has elapsed since the last clean- 
ing process. 

45 [0251] The foregoing process will now be discussed in greater detail with respect to the flow diagram in Figure 35. 
Upon installation and applying power to printer 30 for the first time, in step S3501. a hard power-on begins a cleaning 
schedule process for printer 30. In steps 83502 and S3503, CPU 121 of printer 30 performs its power-on self-test ini^ 
tialization programs by executing process steps stored in ROM 122. CPU 121 uses these programs to check on and 
define various hardware parameters. In step S3504, CPU 121 reads the various parameters stored in EEPROM 132. 

so These parameters have been discussed above in section 6.0. For the purpose of this aspect of the Invention, CPU 121 
is interested in a last cleaning time listed for each print head 130a and 130b. It is this information which is required for 
scheduling a next cleaning time. However, if EEPROM 132 has not been initialized yet, the last cleaning times will be 
set to zero. 

[0252] As explained above, EEPROM 132 maintains profile information on all print heads used in printer 30. There- 
55 fore, in the presently-disclosed embodiment, EEPROM 132 maintains last cleaning times for print heads 130a and 130b 
in separate memory locations. Each cleaning time also is stored with a check sum value. That is, the cleaning times are 
secured with data error correction by check-sum processing or CRC check processing. Both the cleaning times and 
check-sums are mirrored in separate locations or EEPROM 132 in order to prevent loss of the cleaning times which may 
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occur at an accidental power-down, or if a hard-on reset occurs during the middle of a writing operation to EEPROM 
132. As a result, at least one set of cleaning times is quarantined even if an accident occurs. 

[0253] In step S3505, CPU 121 resets variables Delta T_A, which represents an elapsed time since print head A (e.g. , 
print head 130a from Figure 10) was last cleaned. This variable, when enabled, is incremented in one second intervals 

5 and is cleared after every hard power-off. Similarly. CPU 121 also resets Delta T_B for a print head B (e.g.. print head 
130b from Figure 10). CPU 121 resets other indicator flags at this time, such as FlagRealTimeActive which indicates 
whether a real-time has been set or not, FlagRealTimeReset which Indicates whether the real-time has been reset or 
not, FlagRecordYet_A which indicates that Delta T_A value indicates the time of the last cleaning of print head A only 
when the reat-time is not yet set, and FlagRecordYet_B which indicates similar information from print head B. Each of 

10 the variables and flags which are set and reset during the cleaning scheduling process of the present invention are 
listed below in Table 5. 



Tables 



Variable/Flag 


Definrtion 


RealTime 


This ir>dicates that the current tirne and its values are valid only when FlagRealTimeActive is 
set. Also, this will be incremented at every one second if the value is valid. 


Delta T_A 


This indicates the passed time of A-head from the last cleaning and its value is valid only 
when FlagRealTimeActive is reset. Also, this will be incremented at every one second if it is 

valid. 


Delta T_B 


This indicates tiie passed time of .B-head from the last cleaning and its value is valid only 
when FlagRealTimeActive is reset. Also, this will be incremented at every one second if it is 
valid. 


Flag RealTimeActive 


This indicates whether or not the RealTime flag has been set. 


FlagRealTimeReset 


This indicates whether or not the RealTime flag has been reset. 


Flag Record Yet_A 


This Indicates whether the Delta_A value is indicating a passed time from the last cleaning of 
A-head only when RealTime flag is not yet set 


FlagRecordYei_B ^ 


This indicates whether the Delta_B value is Indicating a passed time from the last cleaning of 
B-head only when RealTime flag Is not yet set. 



35 [0254] In step S3506, CPU 121 determines if the last .cleahing time for each of the print heads equals zero. In this 
regard, in a case that the printer is newly installed, these variables will read zero. Therefore, In step S3507, the elapsed ^ 
time since cleaning print head A will be set to a predetermined time, which, as noted above. Is 73 hours. As a result, 
upon performing a soft power-on, printer 30 will.perfbrm a cleaning operation on print head A. Steps S3508 and 83509 
perform similar processing for print head B. 

4o [0255] lnstepS3510, CPU 121 enables the cleaning schedule process. lnstepS3511. CPU 121 awaits a soft power- 
on and commands from host processor 23. In the case of an initial installation, a cleaning process will be performed on 
each print head at this step. 

7.1 Cleaning Schedule Process 

45 

[0256] As discussed above, after initialization. CPU 121 enables a cleaning schedule in step S3510 of Figure 35. The 
manner by which an elapsed time schedule Is maintained will now be discussed in greater detail with respect to the flow 
diagram shown in Figure 36. The shown process is performed at every one second In the case the cleaning process 
has been enabled as an interrupt process. 

50 [0257] Specifically, in step S3601, the cleaning schedule process is enabled and the elapsed time is incremented 
every second for both print heads A and B. In step 83602. it is determined if the RagRealTimeActive has been set. This 
flag will indicate that a real-time has been downloaded from host processor 23. In the case this flag has not been set. 
flow proceeds to step S3603. in which it is determined if the elapsed time since the last cleaning of print head A has 
reached the predetermined maxims time of 73 hours or the maximum value of its variable range. If it has. then flow pro- 

55 ceeds to the automatic cleaning process, discussed below. Alternatively, if tiie value of DeltaT_A reaches maximum 
value, it can be ignored and reset. This will prevent the value from overflowing in rnemory. 

[0258] If the time since last cleaning has not reached the maximum time, then in step 83604 Delta T_A is incremented 
by one second. This process is performed because printer 30 may sit idle for more than 73 hours before receiving a 
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real-time. If this is the case, cleaning will be performed based on an elapsed time from the printer 30's Internal clock, 
later on at soft power-on. or at the automatic cleaning procedure. A similar process is performed for print head B in 
steps S3605 and S3606. 

[0259] In the case that the FlagRealTimeActive has been set, which means that host processor 23 has downloaded 

5 a ttme/date stamp, in step S3607. it is determined if the RealTime reaches the maximum value of 73 hours or at the 
maximum value of its variable range. If it has. then flow proceeds to the automatic cleaning sequence, discussed below. 
Alternatively, if the value of RealTime reaches the maximum value, it may be ignored and reset. This prevents the value 
from overflowing in memory. On the other hand, if the real-time has not reached the maximum value, then the real-time 
Is incremented by one second in step S3608. 

10 [0260] Returning to step S351 1 of Figure 35, upon soft power-on. flow proceeds to step S3701 in Figure 37, which 
waits for a soft power-on. Next, in step S3702. CPU 121 determines if the user has requested a soft power-on. If the 
answer is yes, then in steps S3703 and S3704 CPU 121 performs initialization of software programs ard printer unit 
mechanics. Upon completing initialization, CPU 121 directs, in step S3705. each print head to perform an automatic 
cleaning operation if needed (the automate cleaning operation will be discussed in greater detail below). 

IS [0261 ] After performing the automatic cleaning operation, printer 30 goes online In step 83706 and awaits either print 
comnnands from host processor 23 or a soft power off entered by the user in step S3707. If neither of these events 
occurs, printer 30 remains in a wart state for commands from host processor 23. On the other hand, if a soft power-off 
request has been received, pririter 30, in step S3708 performs its soft power-off process by performing a status check 
and updating parameters in EEPROM 1 32 based on tiie cun-ent status off printer 30. 

20 [0262] In the present invention, printer 30 awaits commands from host processor 23, such as a command to print a 
test pattern, scan the test pattern arxi so on. One command which printer 30 looks for is the universal coordinated time 
(UGT) which provides a time/date stamp to printer 30. The UCT command is used to set the curent time in printer 30, 
arxi must be sent to printer 30 at the onset of a print job start Prirrter 30 uses the time to determine whether or not 
printer 30 should recover print head. The time value is expressed as the number of seconds elapsed since midnight 
^ 25 (00:00 :00), January 1 , 1 970, Universal Coordinated Time (UCT) according to the system clock of host processor 23. In 
this regard, the UCT command is downloaded at the beginning of a print command such that each print command is 
preceded by the UCT command. However.. it is to be noted that only after a hard power-off is tiiere a need to store the 
downloaded time/date stanp since the time which is incremented by printer 30*8 own internal dock is clearedJrom. 
memory at hard power-off. - . - r = '= - 

30 [0263] Thus, with reference to the f bw diagram of Figure 38. in step S3801 , host processor 23 sends a UCT com- 
mand: In step S3802, it is determined if the time and date are valid. In this regard, it is possible that a downloa^ded^ 
time/date stamp is invalid, e.g., if printer 30 has been connected to a host processor which has an internal clock that Is 
ahead of the real-time clock of host processor 23. In some instances, a time and date could be later than the actual last: 
time and date stored in printer 30. If the time/date is not valid due to data formatting error or value out off range, etc., 

35 then the flow will proceed to the automatic cleaning process described in detail below. Alternatively, if the time is invalid, 
an error processing program may be executed, or the invalid time may be ignored. ' ' • • - ' 

[0264] If. in step S3802, it is determined that the current time and date are valid, flow proceeds to step S3803. In step 
S3803, it is defermiried rf tiie reial-time has actually beein stored in printer 30. For example, FlagRealTimeActive may 
not be set. This will be the case when no-real-time has yet been set in printer 30, as would normally occur when printer 

40 30 is being used for the first time and no print jobs have been printed. If FlagRealTimeActive has not been set, then in 
step S3804 the current time and date provided at the t>eginning of the print job is set as the real-time. 
[0265] Flow then proceeds to step S3805. In step S3805. CPU 121 determines, in the case the real-time has not been 
set whetiier the elapsed time for a print head A, such as print head 130a from Figure 10, corresponds to a time of the 
last cleaning of print head A. If it is determined that the elapsed time has been recorded, then in step S3806, printer 30 

45 determines the last cleaning time by sutjtracting the real-time from the stored elapsed time. In step S3807, the last 
cleaning time is written to EEPROM 132 and, in step S3808. FlagRecordYet_A is reset for print head A. Similar 
processing is performed for a print head B, such as print head 130b from Figure 10, in steps S3809 to S3812. In this 
manner, tiie last cleaning tihie and check-sum are updated and are written to EEPROM 132 in separate respective 
memory locations tor each print head A and B. 

50 [0266] Returning to step S3805, if FlagRecordYet_A and FlagRecordYet_B have not been set, ftow proceeds to st6p 
S3813 where FlagRealTimeActive is set in order to indicate that the real-time has been set. 

[0267] Returning to step S3803, iff the real-time has been stored from a previous printing operation and it is deter- 
mined to be a valid time, flow proceeds to step S3814 in which previously-downloaded new time data is compared to 
the real-time data. Iff the differences between th new tim' data and th real-time data are acceptable in step S3815, 
55 then the difference is ignored in step S3818 and flow proceeds. 

[0268] On the other hand, if step S381 5 determines that the differences are not acceptable due to a change in the 
host's real-time clock or an error in the printer's internal clock, in step S3816, the real-time is reset with the new time 
data. In step S381 7, FlagRealTimeReset is set so as to indicate that tiie real-time has been reset. As a result the new 
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time data will be used to calculate when the automatic cleaning should be scheduled for print heads A and B. This pre- 
vents a cleaning process from occurring even if a user acddently resets the host computer's real-time clock to some 
distant time In the future followed by a print job and [UCT] command arKi then reset back to actual current time. 

5 7.2 Automatic Cleaning Process 

[0269] Figure 39 describes the automatic cleaning process. If cleaning is the result of an initial use of printer 30 or is 
a result of a time scheduled cleaning. In step S3901 , it is determined If print head A exists In the printer. If print head A 
does exist in step S3901, CPU 121 checks to see if FlagRealTimeActive has been set. If yes, flow proceeds to step 

10 S3902 to check to see if FlagRealTimeReset has been set. If no, then CPU 121 calculates the Cleaning Time by sub- 
tracting the last cleaning time for print head A stored In EEPROM 1 32 from the real-time. If the difference is greater than 
the preset cleaning time of 73 hours, then in step S3905, print head A is cleaned. However, If the difference is less than 
the preset cleaning time, then flow proceeds to step S3903 and RagRealTimeReset Is set so that the new time data Is 
reset as the real-time. In this case, print head A is forcibly cleaned, because real-time has been reset in step S3817. 

15 [0270] Reverting to step S3902, if FlagRealTimeActive is not set flow proceeds to Step S3906. In step S3906, the 
elapsed time for print head A Is compared to the Cleaning Time. If greater than or equal to 73 hours has elapsed since 
print head A was cleaned, and print head B Is not installed, flow proceeds to step S3913 at which time FlagReal- 
TimeReset is reset. Step S3913 will normally be executed when printer 30 has not been used since a hard power-on. 
[0271] . In the case that print head B is installed, similar processing is performed for print head B in steps S3907 to 

20 steps 33912. 

7.3 Cleaning Of A Print Head 

[0272] Figure 40 Is a more detailed description of the operations performed in steps S3905 and S391 1 of Figure 39. 

25 In step S4001 , It Is determined If a print head is installed. If it is determined that a print head is installed in step S4001 , 
a cleaning operation is performed in step S4002. The cleaning operation consists of moving the print head to its home 
location, aligning nozzles on the print head to be cleaned with print head connection cap 88a (see Rgure 4), suctioning . 
ink from the nozzles,; and depositing waste ink In a waste well. The nunr^er of droplets sucked from the print head Is 
counted and this information is updated in EEPROM 132 in the same manner as discussed above with respect to updat- 

30 ing last cleaning times. 

[0273], . In step 84003, It Is determined if FlagRealTimeActive Is set. In the case that tiie flag is set, the last cleaning ; 
time of the cleaned print head is set as the real-time in step 84004. In step 84005, the real-time, which is the last clearv 
ing time of the print head, is written to EEPROM 132. 

[0274] Returning to step S4003, if FlagRealTimeActive is not set. since a UCT command has not been downloaded 
35 to the printer in the last 73 hours. Iri step S4006 the elapsed time is set to zero and FlagRecordYet for the particular print 
. head is set In step 84007. This will indicate that the real time has not been set in step 84007 and the elapsed time coun- , 
ter r^arts. 

[0275] As mentioned previously, cleaning of a print head will be performed in the case that tiie print head or the ink 
cartridge has been replaced. Figure 41 is a detailed flow diagram regarding the cleaning of a print head following such 
40 an event. 

[0276] In step 84101 , print head replacement processing begins. In step 84102, CPU 121 awaits the termination of 
a head replacement mode by the user. In step 841 03. the replacement process is terminated. Therefore, in step 841 04, 
CPU 121 checks to see which head has been removed; i.e., which print head has engaged and disengaged a circuit 
contact on its corresponding cartridge receptacle. If print head A has been removed, then in step 84105 print head A 
45 is cleaned. The cleaning is performed in the same fashion as described with respect to the flow in Figure 40. Similar 
processing is performed for print head B In steps 84108 and 84107. 

[0277] . The ffow diagram in Figure 42 describes what occurs when an automatic cleaning process is scheduled and 
paper has been loaded into a prirrting position in printer 30. In the case that paper has been loaded into the printing 
position arxi an automatic cleaning has been scheduled, the paper is ejected by a command in order to complete the 
so printing in step 84201 . Once the paper has been ejected, automatic cleaning of one or more print heads is performed 
in step 84202. Following the automatic cleaning process, a new paper is loaded into the printing position in step 84203. 
In this regard, steps 84201 and 84202 will be executed folfowing every automatic cleaning regardless of whether a 
paper was previously loaded. 

[0278] Figure 43 is an example of a typical cleaning schedule for a print head, which is performed In accordance with 
55 the present invention as described above with respect to Rgures 35 to 42. Before describing the typical cleaning sched- 
ule, it should be understood that printer 30 maintains separate cleaning times and cleaning schedules for each of print 
heads 130a and 130b. The reason for this is that one print head may be replaced before the other or one may not be 
used in a 73 hour period. For example, when printing only text documerrts, the black print head will be used more than 
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the colored print head. Therefore, the black print head may need to be cleaned more frequently than the color print 
head. That is. it may not be necessary to clean the color print head until immediately before a printing even if it has been 
more than 73 hours from last cleaning and soft power-on has.occurred. In this manner, ink may be saved. 
[0279] Figure 43 is a time tat)le which shows five separate time periods (T1 - T5) being downloaded to printer 30. The 

5 time periods shown in Figure 43 begin at a time period of when the printer is first installed. 

[0280] At initial hard power-on. printer 30 performs its Initialization process and the last cleaning times are read from 
EEPROM 132. Because it is the first power-on. all flags and variables are reset. As discussed above, this reset will Ini- 
tiate a cleaning process upon the soft power-on. In the example shown in Figure 43. because a soft power-on is per- 
formed prior to installing a head into the printer, a cleaning will not be performed until the head is installed. Once the 

10 head is installed, an automatic cleaning is performed for each of print heads 130a and 130b. The Delta_T variable is 
set to 0 for all print heads and FlagRecordYet is set as discussed above in steps S4006 and S4007. 
[0281] Once the print heads are cleaned and software has been initialized, printer 30 goes online. Recognizing that 
printer 30 is online, host processor 23 sends the first print job and a universal coordinated time (UCT) command, which 
provides the current date and time stamp. When the UCT command is received for the first time, RagRealTimeActive 

75 is set and the new time is set as the real-time. In the present example, because the last cleaning was less than 73 hours 
since the print head was installed, an automatic cleaning process is not performed at T1. 

[0282] In the time chart example shown In Figure 43, the next time at which a cleaning time is set is when the head 

is replaced at T2 and it is at this time that cleaning will take place regardless of elapsed time. 

[0283] As mentioned previously, the UCT command prefaces every print command. Therefore, according to this sam- 

20 pie time chart shown in Figure 43. a print command provides the next new time data at T3. Assuming that it is a valid 
time and FlagRealTimeActive has been set, the difference between the new time data and the real-time data is calcu- 
laited. In tiie case shown in Figure 43, the difference between time T3 and time T2 is greater tiian 73 hours, and a clean- 
ing is pebformed. Since the internal clock of printer 30 has been active since the previous date stamp, the elapsed real- 
time should be the same as the new real-time downloaded at the beginning of the print job. As a result, there is no need 

25 . to store the newly downloaded time. 

[0284] Following printing of the print job, printer 30 performs a hard power-off which clears all stored times. A haixJ 
pdwer-on follows and resets all flags and variables. The hard power-on is followed by a soft power-on which places 
printer 30 online. Once online, the host processor sends a print job which is prefaced with a UCT command which prd- 
vides the current time and date at T4. As discussed with respect to Figure 38, since FlagRealTimeActive has not been 

30 set. the real-time that is download is stored as the new time arKi FlagRealTimeActive is set. 

[0285] At thistime. CPU 121 determines if print heads 130a and 130b are installed, if FlagRealTimeActive is set arid ; 
whether FlagRealTlmeRieset is set. Because a new time has been provided by host processor 23, the difference 
between the real-time and the last cleaning time of a print head is calculated. As shown in Figure 43, the difference : 
between time T4 and time T3 is greater than 73 hours. As a result, a cleaning is preformed at T4. 

35 [0286] Following the last print job. a hard power-off occurs which clears the stored times. The next hard power-on 
resets all variables and flags: As previously discussed; after a hard power-on, elapsed time variat)les are incremented' 
in intervals of one second. As shown in tiie example in Rgure 43, a period of 73 hours eliapses before the next soft 
power-on. As a result, a cleaning rs performed. This cleaning is performed based on printer 30*s own internal elapsed 
clock and not a real-time download because printer 30 has been idle for more than 73 hours without receiving a print 

40 job. Alternatively, cleaning of the print head, after 73 hours has elapsed on tiie internal clock, may not be required and 
may be rescheduled for immediately before a printing operation. By postponing cleaning until immediately before print- 
ing in this manner, ink can be conserved. 

[0287] As mentioned above, EEPROM 132 can be replaced with any kind of non-volatile mennory such as a static- 
ram witii battery backup, or flash memory, etc. In this case irifbrmation, including the last cleaning time discussed 

45 above, can be stored in similar types of non-volatile memory devices. 

[0288] Furthermore, ROM 122 can be replaced with any kind of rewritable memory device, such as a flash memory, 
etc. In this case, such memory devices can receive program code downloaded to printer 30 via interface 104 of host 
processor 23 and host computer interface 141 of printer 30. It is also possible to utilize a memory device to memorize 
all information in a specific area of the memory device instead of EEPROM 132. 

so [0289] In addition, although communication line 106 was deccrlbed as bi-directional, even a unidirectional interface 
can be used with this invention. More specifically, while the IEEE- 1284 interface was implemented in the above descrip- 
tion, any kind of interface like SCSI, USB (Universal Serial Bus), and IEEE-1394 (high speed serial bus interface), etc. 
may be used in its place. 

[0290] Finally, the embodiment of the present invention was described using two print heads. However, it shouW be 
55 understood that this number could be increased or decreased. Likewise, the number of memory locations in EEPROM 
132 and RAM 129 can be either increased or decreased based on the number of print heads used in printer 30. 
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8.0 Setting And Modifying Print Head Driving Parameters 

[0291] Because print lieads 130a and 130b are designed to be removable and replaceable into printer 30. and 
because different kinds of cartridges (such as cartridges tiaving different nozzle corrf igurations and different ink char- 

5 acteristics) can be loaded into print head receptacles 64a and 64b, printer 30 is pre-loaded with print head driving 
parameters for many different types of print heads. For example, the pulse width sequence for driving each individual 
nozzle so as to eject an ink droplet is heavily dependent on temperature of the print head, ink characteristics (for exam- 
ple, whether color or black and whether dye or pigment), temperature of the sunounding environment, ink droplet size, 
and the like. As a consequence. ROM 122 includes pre-stbred tables defining driving pulse sequences for various 

10 head/ink/resolution combinations. The pre-stored tables in ROM 122 cover various known combinations of 
head/ink/resolutions, as well as arrticipated combinations of head/ink/resolutions. 

[0292] Likewise, parameters used to make internal calculations such as calculations of print head temperature are 
also dependent on each particular combination of printer head arxJ nozzle configurations, ink type, and resolution. For 
the same reason, therefore, printer 30 includes within ROM 122 various tables of heat-up coefficients for known com- 

15 binations of head/ink/resolution, as well as anticipated combinations of head/ink/resolution. 

[0293] The inventors herein have recognized that it is not possible to anticipate all possible combinations of head, ink 
and reso!ution> and to pre-store suitable tables for all such combinations. The reason for this is simple: It is not known 
what new developments in printer heads and inks might occur In the future. At the same time, there is a desire to utilize 
printer 30 with any combination of head and ink and resolution that might occur in the future, without requiring a new 

20 set of tables in ROM 122. Particularly, new tables would require re-manutecture of printers, and an upgrade program to 
distribute new ROM's to existing customers. 

[0294]. , Onoiembodiment of the present invention addresses this desire by providing for modification of the values in 
pre-stored tables via commands from host processor 23, and by permitting real-time definition of print head control 
parameters from host processor 23. By virtue of these features, it is possible through the use of commands from host 
25. processor 23 to define print head driving parameters which are suitable for controlling the functionality of newly-devel- 
oped cartridges, or other cartridges for which pre-stored tables in ROM 122 are not available, ordinarily without chang- 
ing ROM tables or other printer hardware. 

[0295] Briefly, according to this aspect of the invention, a printer controller that receives commands from an external 
processor controls a process function of a printer having a detachable cartridge based on the commands. The com- 
30 mands are capable of defining new cartridge driving parameters which are tailored to control functionality of new car- 
tridges for which pre-stored driving parametersyare not already, available in the printer. Such parameters include, for 
example, timing for heat pulse sequences so as to eject ink droplets, heat-up coefficients for calculating print head tem- 
peratures needed for such heat pulse sequences, print speed, droplet size, buffer readout control, nozzle firing 
sequence, and the like. 

35.\. [0296] Figure 43A is a flow diagram illustrating a first enrdsodimerrt of the invention, in which a command that defines 
. driving control parameters for a print head is comprised by a command to modify values in pre-stored tables of print. . 
head driving conditions. Briefly, according to Figure 43A, to control print head driving conditions in a printer having a 
pre-stored look-up table defining pre-stored print head driving conditions for at least one of plural detachable print 
heads, an external host processor sends a command to modify the pre-stored look-up table such as by modification 

40 through multiplication by a control ratio. A print confroller obtains print head driving corxJItions form the pre-stored look- 
up table arxi modifies the print head driving conditions so as to obtain modified print head driving parameters. The mod- . 
if ied print head driving parameters are then sut>sequentiy used for print operations. 

[0297] In more detail, in step S43101 , printer 30 receives a command to set a control ratio for driving a print head 
pulse width sequence. The command Is sent by host processor 23 (step S43102), and In the absence of receiving any 
45 such comnnand, printer 30 maintains a default value of 100%. The control ratio for driving that is received In step 
S43101 is a factor applied to look-up values from a pre-stored table in ROM 122, as described more fully below in step 
S43112. 

[0298] In step S431 03, printer 30 receives a command for a confol ratio for head temperature calculations. The com- 
mand is received from host processor 23 (step S43104), and in the absence of receipt of such a command, printer 30 
so maintains a default value of 1 00%. The control ratio for head temperature calculations is applied as a multiplication fac- 
tor against pre-stored values of heat-up coefficients used for calculating head temperature, as described more fully 
below in connection with step S431 15.. 

[0299] Preferably, steps S43101 through S43104 are effected through use of the change pulse ratio command 
([PGR]) defined above in Section 3.6. As described above, \he [PGR] command is used to change a ratio of pulse con- 
55 trol tables such as a ratio of heat-up coefficients used for calculating head temperature, and such as changing a ratio 
of pulse widths for a pulse width driving sequence for each individual nozzle of print heads 130a and 130b when eject-, 
ing an ink droplet from tiie nozzle. 

[0300] Flow continues in printer 30 with steps S43106 through S431 15 which are executed repeatedly at cyclic inter- 
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vals of, for example. 50 ms so as to maintain in real time the most current values for print head driving parameters. More 
specif really, as described above in connection with Figure 23, steps S43106 through S43115 are executed at 50 ms 
cyclic intervals, for example, so as to calculate head temperature and to derive pulse width timings for a pulse width 
sequence applied to eject an ink droplet from a nozzle, together with other tasks also executed at 50 ms intervals. 

5 [0301] Referring again to Figure 43A, step S43 106 reads current environmental temperature (Tenv) ffom an unshown 
thermistor in printer 30. The current environmental temperature may be the most current value read from the thermistor, 
or more preferably the actual value read from the thermistor is subjected to low pass filtering so as to smooth any irreg- 
ularities, discount bad readings of the thermistor, remove noise such as analog-to-digital sampling noise, and the like. 
[0302] Based on the environmental temperature Tenv ^^'^ in step S43 106. a target tenrperature (Ttg,) is calculated in 

10 step S43107. The target temperature is the preferred operational temperature for printer 30 based on the current envi- 
ronmental temperature. Generally speaking, printer 30 is controlled through unshown heaters in print heads 130a and 
130b so as to reach the target tenfpeirature, as explained above in connection with Figure 23 at the 500 ms interrupt 
level. The target temperature is the nrxfel preferred temperature for print head operation based on the current environ- 
mental temperature. The relationship between target temperature and environmental temperature is inverse, meaning 

IS that low environmental temperatures result in relatively higher target temperatures, whereas high environmental tem- 
peratures result in relatively lower target tenperatures. For example, at extremely low environmental temperatures such 
as Terw = 5**C. a preferred target temperature might be T,gt = 35*C, whereas at extremely high environmental tenrpera- 
tures such as Tenv = 35**C, a preferred target temperature might be Ttgj = 15**C. 

[0303] Step S43109 calculates the effect on print head tenrperature caused by actual ink droplet ejection from print 
20 heads 130a and 130b. More particularly, the environmental temperature read In step S43 106 is based on an environ- 
mental temperature read by a thermistor mounted exteriorly of print heads 130a and 130b. Proper control over print 
head driving parameters, on the other hand, is more directly affected by the internal temperature of ink adjacent the 
print head nozzles. It is not generally considered practicable to mount a thermistor within such a small area. At the same 
time, it is known that active ink droplet ejection will cause a rise in ink temperature and that in the absence off any ink 
25 ejection, Ink temperature will generally fall. It is the purpose of step S43 109 to calculate the effect of print head temper- 
ature caused by ink droplet ejection to make this calculation. 

[0304] The calculation of print head temperature in step S43109 is nnade based iri part on the number of ink droplets 
actually ejected over a previous time interval such as 50 ms. Each ejection of an Ink droplet within the predetermirled 
time interval is assigned a heat coefficient weight. Based on the number of ink droplet ejections within the predeterr 

30 mined time period, it is possible to calculate the effect of ink droplet ejection on print head temperature. 

[0305] At the same time, it is known that such heat-up coefficients vary in dependence on the particular type of print 
head used, the ink characteristics used in the read, the resolution of printout by the head, and the like. Each different 
combination of head/ink/resolution changes heat-upi coefficient values corresponding to the number off dots printed. 
Accordingly, ROM 122 is pre-stored with tables for heat-up coefficients. This situation is illustrated In Figure 43B. 

35 [0306] As shown in Figure 43B. one portion of ROM 122 includes pre-stored tables 701 for heat-up coefficients: The 
tables include plural tables 702a, 702b. etc.. one table for each different combination of printer head, ink characteristics, 
and resolution. Each of the plural tables includes tabularty accessed coefficients such as the coefficients labelled 1 , 2 
and 3 (reference nunrierals 703. 704 and 705), which are accessed through look-up operation based on the number of 
ink drops ejected in any one particular interval, for example. 50 ms (as indicated at reference numeral 706). Printer 30 

40 selects one heat-up table from the tables stored at 701 , based on a default selection or based on a commanded selec- 
tion (as described below in connection with Figure 43C)i and then selects heat-up coefficients from the selected table 
based on the nunnber of droplets ejected in a 50 ms period. 

[0307] The coefficients obtained through look-up operation in tables 701 are used to calculate the effect on print head 
temperature by ink droplet ejection. One suitable calculation is as follows: 

45 

AT main = (coeffl * (# black droplets ejected)) + (coeff2 * {# color 
droplets ejected)) + (coeff3 * (heater duty cycle)) .- coeff4 

50 where coeffl 1 is a heat-up coefficient based on the number of black ink droplets ejected, coeff2 is a heat-up coefficient 
based on the number of color droplets ejected. coeff3 is a heat-up coefficient based on the current duty cycle of the 
heater, and coeff4 is a heat-up coefficient which actually, shows cool down of the print head based on Inactivity. Of 
course, the actual coefficients and calculations used depend on the head/ink/iresolution combination. For example, the 
calculation given above is suitable for a four-color print head whereas an all-black print head would use a diffferent cal- 

55 culation that excludes, for example, dependence on the number of color droplets ejected. 

[0308] Armed with the environmental temperature Tenv the target temperature T,gt and the print head temperature 
effect AT^ain, step S431 1 0 calculates the difference ATjiff. as follows: 
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[0309] Step S43111 accesses a look-up table in ROM 122 that stores pulse wicfth times for a pulse width driving 
sequence, based on the temperature difference Tdm- Suitable tables are illustrated diagrammatically in Rgure 43B as 
5 described below. 

[0310] Specifically, as shown in Figure 43B. ROM 122 includes look-up table 710 for storing driving times. The driving 
times are pulse widths for a pulse sequence used to drive nozzle heaters to eject an ink droplet. A typical pulse 
sequence is shown at 4331 1 in Figure 43 A, and includes a pre-heat pulse of width T^^^, a quiescent period of width T\j^, 
and a main heating pulse of width Tr^ain- ^"ch a pulse sequence is applied to nozzle heaters in each nozzle of print 
10 heads 130a and 130b so as to eject a droplet of ink for printing. It is the purpose of table 710 to calculate each of X«p. 
Tjnt and Tn^in t^sed in part on the temperature difference calculated in step S431 10. 

[031 1 ] At the same time, it is recognized that the pulse widths of the pulse driving sequence differ based on particular 
combinations of print head, ink characteristics, resolution, and the like. Accordingly, as shown in Figure 43B, tables.710 
include individual tables such as 712a, 712b, etc. Each table 712a, 712b. etc. is tailored for a particular combination of 
IS print head, ink type and resolution. As shown at 710. each table includes entries 714 for the width of the pre-heat pulse 
Tpre. entries 71 5 for the width of the quiescent interval T\nt» and entries 71 6 for the width of the main heating pulse Tmain- 
Any one particular entry Is accessed through look-up operation based on the temperature difference Tdiff calculated at 
stepS43ll0. 

[0312] Printer 30 selects one tatAe of driving time from the tables stored at 71 0, based on a default selection or based 
20 on a commanded selection (as described more fully below in connection with Figure 43C). Printer 30 thereafter 
accesses the entries in the selected table, and looks up appropriate times for the pre-heat pulse, the quiescent interval, 
and the main heat pulse, all based on the tenrperature difference calculated in step 8431 10, and in a particular conr^i- 
nation of print head/ink/resolution. 

[0313] Reverting to Figure 43A. step S431 12 modifies the driving times obtained by look-up operation from table 710. 

25 based on the control ratio for driving that was received in step S43101 . The purpose of this step is to allow for modifi- 
cation of pre-stored values from look-up tat>les 710, taking into consideration any difference between an actual print 
head mounted in printer 30, and the print head combination stored in table 710. In more detail, and as explained previ- 
ously, although ROM 122 of printer 30 is pre-stored with plural tables for driving times, with each tatrfe tailored to a par- 
ticular combination of print head/ink and resolution, it is rK>t possible to anticipate each and e^ery combination of print 

30 head/ink and resolution. Modification in step S43112. therefore, allows for use of previously unknown, or othenwise. 
unstored. combinations of print head/ink and resolution. > 

[0314] Modification in step S431 12 is preferably through multiplication of the driving times obtained through look-up 
operation in step S431 1 1 by the control ratio received in step S43101 . For this reason, the default control ratio is 100%. 
The control ratio that is commandable through the change pulse control ratio command [PGR] is constrained to lie 

35 between 1 % to 200%, thereby allowing nriodif ication of pulse tirnes from effectively negligible pulse times up to twice the 
values stored in tables 710. ... 
[0315] Flow then advances to step 843114^ in vyhich printer 30 looks up heat-up coeffk^ients for head temperature 
calculations. As described previously in connection with tables 701 of Figure 43B, heat-up coefficients are obtained 
based on a particular combination of print head, ink and resolution, and are looked up frorn one of tables 702a, etc. 

40 based on the number of dots printed per cycle, each having a duration of approximately 50 ms. 

[0316] Step S431 15 modifies the heat-up coefficients basied on the control ratio received in step 843103. Again, the 
purpose of such modification is to permit lisage of a particular combination of print head, ink and resolution not already 
stored in one of tables 701. 

[0317] Preferably, modification of the heat-up coeffidents in step 8431 15 is through multiplication of the coefficients 
45 obtained through look-up operation in step 8431 14 by the control ratio received in step 843103. For this reason, the 
default control ratio is 100%. The control ratio that is commandable through the change pulse control ratio command 
[PGR] is constrained to lie between 1% to 200%, thereby allowing modification of heat-up coefficient from effectively 
negligible values up to twice the values stored in tables 701 . 

[0318] In step 8431 16, printer 30 controls nozzle driving based on the modified driving times obtained in step 8431 1 2, 
so all in response to a command from host processor 23 that sends print data to printer 30, and a command for printer 30 
to print such data (step 8431 17). Flow repeats as before, with steps 843106 through 8431 15 being executed at 50 ms 
cyclic intervals, for example, and with control over nozzle driving based on modified driving times, as set out in step 
8431 16. being executed as corhmanded by host processor 23. In addition, it should be recognized that control ratios 
for driving, as well as control ratios for head temperature calculations, may be sent from host processor 23 at any time, 
55 and are resporxied to by printer 30 as set out in steps 843101 and 843103 described above. 

[031 9] Figure 43G shows another embodiment of the present invention by which commands capable of defining print 
head driving parameters for a printer having a detachable print head are sent from an external device such as host proc- 
essor 23 to a print corrtroller. One difference in the embodment shown in Rgure 43G from that shown in Rgure 43A, is 
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that rather than responding to a parameter that modifies pre-stored print head driving parameters, the ennbodiment of 
Figure 43C responds to actual print head driving parameters. Generally speaking, parameters received in Figure 43C 
control readout order for data in print buffer 139, control the nozzle firing sequence for individual nozzles in a print head, 
control droplet size for droplets ejected from the nozzles, and control other print head driving parameters. Preferably, 
5 commands from host processor 23 define plural sets of each of txjffer controls and nozzle firing sequences. These 
buffer controls and nozzle firing sequences are registered in RAM 129 of printer 30. By subsequent commands from 
host processor 23, any of the registered sets of buffer controls or nozzle firing sequences may be selected for use in a 
particular scan, or plural scans, of a print head across the printing medium. 

[0320] In more detail, in step S43351 , host processor 23 sends a buffer control command to printer 30. and In step 

10 S43352 printer 30 receives the buffer control command and responds appropriately as described below. The buffer con- 
trol commands sent in step S43351 may be of two types: a first type that defines a buffer control sequence, and a sec- 
ond type that selects one of plural buffer control sequences already defined in printer 30. With respect to the first type, 
which defines kxjffer control sequences, host computer 23 defines buffer control sequences by which data is read out 
from print buffer 139 during print operation by printer 30. In response to such a command, the buffer control readout 

15 order is stored in RAM 1 29 by printer 30 for later selection/Preferably, to define a buffer control readout order, the define 
buffer control table command ([DEFINE_CONTROL]); described above in Section 3.6. is used. 
[0321] Once plural buffer control readout orders are registered in RAM 129. the second type of buffer control com- 
mand allows host processor 23 to select any one of them for use in sut^sequent printout operations. Preferak>ly, the 
select buffer control table ([SELECT_CONTROL]) command defined above in Section 3.6 is used in this operation. 

20 [0322] Figure 43D illustrates two different buffer control readout orders, as examples of the buffer control tables that 
may be registered in RAM 129 based on the [DEFINE_CONTROL| commarxj. The reason that such buffer control rea- 
dout orders are needed is to accommodate at least three different factors that affect how data must be read from print 
buffer 139 during a print operation. The first such factor is the a slant adjust of print nozzles as they are anranged on the 
print head. This factor has been described above in connection with Figure 8, which illustrates that nozzles are prefer- 

25 ably in a slightly slanted (oblique) direction such that for every 16 nozzles there is a lateral displacement of one 
pixel/360 dpi. two pixels/720 dpi, and four pixels/1 440 dpi. - 
[0323] The second factor among those affecting tHjffer readout order is the prirrt head configuration, and the nozzles 
actually used during a printing operation. This factor is explained in connection with Figures 43D. 43E and 43F. which 
show examples of kxjffer readout order for a variety of print head configurations and nozzles, as well as resolution. ; . 

30 [0324] Figure 43D shows one possible print head configuration, in which a print head consists of 24 nozzles for each 
of yellow, magenta and cyan inks, arranged slantingly vertically on top of 64 nozzles for black in. For four-color printing.^ 
usually only 24 black nozzles out of the total of 64 such black nozzles are used, in correspondence to the 24 nozzles 
for the three other colorants. Physically, however, there is a considerable offset between the 24 black nozzles used for 
printing, and the ck5sest adjacent nozzle of cyan: In addition, the cause of the nozzle offset length, explained above in 

35 connection with Figure 8, buffer readout order must compensate for the nozzle offsets in the horizontal direction. 

[0325] Buffer readout order corhper^tes for these effects as follows. First, the actual nozzle arrangement 740 is 
defined with respect to a fictitious standard: a print head having 256 nozzles. Since the print head of Figure 43D actually 
has the 24-24-24-64 nozzle arrangement described above for the yellow, magenta, cyan and black inks, the start posi- 
tion for nozzles actually commences at a location 15 bytes lower in a print buffer than wouM begin with a 256 nozzle 

40 head. Thus, a nozzle start position 741 Is defined as 15 bytes. Thereafter, byte locations for nozzle offsets are defined 
for each successive group of nozzles. As shown in 742, nozzle offsets corresporxi to one byte for each of the yellow, 
magenta and cyan inks. Because the gap between the last adjacent cyan nozzle and the first black nozzle actually used 
for printing corresponds to six bytes against the standard 256 nozzle head, a nozzle offset of six is defined for the first 
black nozzle actually used in printing. 

45 [0326] A txiffer readout control further defines the buffer data height 743 in bytes (in this example, buffer data height 
is 1 2 bytes) and print buffer height 744 (In this example, print buffer haght is 1 2 bytes). 

[0327] To control buffer readout order in compensation for nozzle slant, a start position 745 is defined for locations in 
the print buffer, a portion of which is designated at 746. Each, subsequent offset for eight nozzles, which correspond to 
a single eight bit byte in the print buffer, is specified as shown at 747. In the example of Rgure 43D, buffer readout order 

50 is being specified for 360 dpi printing. At this resolution, the nozzle slant corresponds to one printed pixel horizontally 
for 16 vertical nozzles. Accordingly, the first two bytes in the print buffer (corresponding to 16 bits, one for each of the 
first 16 nozzles in yellow ink), are read out sequentially. However, at 360 dpi resolution, the next nozzle for yeWaw ink 
will actually be printed one pixel horizontally away from the previous 16 nozzles. To conrpensate for this horizontal off- 
set, a buffer offset of 13 bytes is provided, so as to permit printing of the final eight nozzles of yellow ink in proper vertical 

55 relationship to the pre^/ious 16 nozzles. Since there is a physical gap corresponding to eight nozzles between yellow 
and cyan inks, as shown in Figure 8, there is no need to provide readout data for the non-existent nozzles in the gap. 
[0328] Since the first nozzle for magenta printing is located a physical distance of 16 nozzles away from the beginning 
of the last print buffer readout for yellow nozzles, an additional 1 3 bytes offset must be provided between printing for the 
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last set of yellow nozzles and the first set of magenta nozzles. Similarly, offsets of plus one byte, plus 1 3 bytes, plus 1 3 
bytes, plus 1 byte and plus 13 bytes are provided, in sequence, for the remainder of magenta printing, and for the cyan 
printing. 

[0329] With respect to black ink printing, because the location of the 24 black nozzles actually used for printing cor- 
-'s responds to a horizontal shift of three pixels due to the slant angle shown in Figure 8, and because of the eight nozzle 
between cyan and black nozzles, an offset of 37 bytes is needed for buffer readout order. This also is depicted at 747. 
[0330] Thus, in summary, buffer readout order is affected by physical arrangement of nozzles on the print head, 
including gaps and slant angles, actual nozzles used for printing, print resolution and the like. One way to specify buffer 
readout order therefore involves a specification of the nozzle start position, nozzle offsets, print buffer data height, print 
10 buffer height, and byte offsets for bytes in the print buffer that con'espond to nozzles used in printing. 

[0331] This arrangement is shown again in connection with Figure 43D which shows printing at 720 dpi. Since print 
head configuration has'not changed, nozzle offsets and the like are not necessarily different. However, since at 720 dpi 
the slant angle of Figure 8 corresponds to a two pixel horizontal offset for every 16 vertical nozzles, buffer offsets must 
be changed as shown at 749. 

IS [0332] Additional examples of how to specify buffer readout order for different combinations of print head configuration 
(including physical arrangement of nozzles on the print head and slant angle of the nozzles), actual nozzles used during 
prirrting. and print resolution, are given In Rgures 43E and 43F. Figure 43E; for example, shows printout using the same - 
print head shown in Figure 43D, but using only all 64 black nozzles and without using any color nozzles. Thus, as shown 
at 750, with respect to a fictitious standard of a 256 nozzle head, the first nozzle involved in printing Is located 24 bytes 

20 tower. Accordingly, the nozzle start position 751 is altered appropriately, as are the nozzle offsets 752 which include 
eight successive eight bit bytes. Print buffer data height changes as shown at 754 to eight bytes, although print buffer 
height 755 remains at 12 bytes. Buffer offsets 756. overlayed onto a portion 746 of the physical print buffer, indicate off- 
sets for proper readout order of each byte from the print buffer 
[0333] Buffer offsets for printing at 720 dpi resolution are shown at 757: 

25 [0334] Figure 43F shows examples of buffer readout order when using a print head comprised of 1 28 nozzles of black 
ink an^anged sequentially on a print head with a slant angle, as shown at 98 in Figure 8. Such a nozzle arrangement 
759 differs from the fictitious standard of a 256 nozzle head by beginning at a nozzle start position 760 of 16 bytes 
lower. Nozzle offset 761 indicate 16 sequential eight bit groups of nozzles. Print buffer data height 762 is set at 16 bytes, 
as is print buffer height 764. Buffer offset 765 shows how the buffer readout order is affected by the slant of the print 

30 heaids. as overlayed onto a portion 746 of the print buffer. 

[0335] For printing at 720 dpi resolution, buffer offsets eire as indicated at 766. 

[0336] The third factor among other factors affecting readout order is print resolution. In particular, when printing at a 
. high resolution, a slower carriage speed is used than when printing at a low resolution. Because of the difference in car- 
riage speed, and how tiie difference calculates into the effect of the non-oblique arrangement of the print nozzles, it is 
35 necessary to modify buffer readout order basied on print resolution. 

[0337] Thus, in surhmary, step S43351 sends plural buffer control tables to printer 30. where they are registered in / 
step S43352. One such table is selected for use during actual printing operations. 

[0338] In step S43354, host processor 23 sends nozzle firing sequence commands to printer 30. Nozzle firing 
sequence commands sent from host processor 23 are received by printer 30 in step S43355 and processed appropri- 

40 ately as described below. Generally speaking, step S43354 sends one of two types of nozzle firing sequence com- 
mands: a first type which defines plural different nozzle firing sequences, and a secorxi type in which one of the 
previously-defined nozzle firing sequences is selected for use during a subsequent printing operation. For the first type 
of nozzle firing sequence command, in which nozzle firing sequences are defined, host processor 23 preferably sends 
the define heat pulse table command ([DEFINE_PULSE]). described above in Section 3.6. For each such nozzle firing 

45 sequence defined by host processor 23, printer 30 responds by registering the nozzle firing sequence in RAM 129. 
[0339] For the second type of nozzle firing sequence command, host processor 23 selects one of the plural previously 
registered nozzle firing sequences for use in subsequent printing operations. Preferably, host processor 23 utilizes the 
select heat pulse table command ([SELECT_PULSED described above in Section 3.6. Upon receipt of the select heat 
pulse table command, printer 30 retrieves the designated one of the previously registered heat pulse tables from RAM 

so 129. and utilizes it for subsequent printing operations such as the next scan or plural scans of print heads 130a and 
130b across the print medium. 

[0340] Examples of different nozzle heating sequences are illustrated in Figure 43G. The reason that different nozzle 
firing sequences are needed is because the actual nozzle firing sequence is dependent on many factors including res- 
olution, direction of scan (i.e., fonward or backward), and slant angle of the nozzles. Other factors also affect nozzle fir- 
55 ing sequence. Resolution, for example, affects nozzle firing sequence since for a low resolution printout, a print head is 
moved across a carriage at a high speed. This speed is calculated so that as 16 nozzles are fired, the carriage 
advances by exactiy one pixel/360 dpi, two pixels/720 dpi. or four pixels/1440 dpi, in corresponderKe to the slant angle 
of the nozzles. This results in a situation where a vertical line will be printed if the nozzles are fired sequentially, from 
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top to bottom. On the other hand, at a low resolution, the canriage speed is slowed. Accordingly, so as to result in a ver- 
tical line, It is necessary to fire every other nozzle in sequence. Thus, resolution is one factor that affects the nozzle fir- 
ing sequence. 

[0341 ] Print direction is another factor annong others that affect nozzle firing sequence, as can be readily understood. 
5 Specifically, because of the slant angle, the nozzle firing sequence must be reversed between forward and backward 
printing. 

[0342] Figure 43G illustrates some examples of nozzle firing sequences that can be defined by host processor 23 and 
registered in printer RAM 129. for subsequent selection of one sequence. As shown in Figure 43E, nozzle firing 
sequences for nozzle numbers 1 through 16 are defined for each of four different printing conditions: 360 dpi printing in 

10 a fonward direction. 360 printing in a reverse direction. 720 dpi printing in a fonward direction, and 720 printing in a 
reverse direction. Each of the four nozzle firing sequences is defined by host processor 23. and transmitted to printer 
30 whereupon printer 30 registers the nozzle firing sequence in RAM 129. Thereafter, host processor 23 selects one of 
the nozzle firing sequences, as appropriate to the currently desired printing condition, and transmits a suitable select 
command to printer 30. Printer 30 responds to the command by selecting the designated nozzle firing sequence, and 

IS using it for subsequent printing operations. 

[0343] Thus; in summary, step S43354 altows host processor 23 to define plural different nozzle driving sequences, 
one of which is designated for use in a subsequent printing operation. In step S433S5, printer 30 responds to com- 
mands from host processor 23 by registering each of plural nozzle firing, sequences in RAM 129, and selecting a des- 
ignated one of the registered nozzle firing sequences for use in subsequent printing operations. 

20 [0344] In step S43356. host processor 23 sends a droplet size command such as the [DROP] command described 
above in Section 3.6. and in step S43357. printer 30 responds to the droplet size command by selecting the droplet size 
commanded thereby. Printing is thereafter effected in the droplet size. 

[0345] In step S43359. host processor 23 sends print data (preferably witii the [DATA] command), and thereafter com- 
mands printer 30 to effect printing of tfie data (with tiie [PRINT] command). Printer 30 responds in step 843360 through 
25 S43362. by controlling readout order from printer buffer 139 based on the buffer control command selected in step 
S43352. by controlling nozzle firing sequence based on the nozzle firing sequence command received in step S43355. 
and by controlling droplet size based on the droplet size command received in step S43357. 

[0346] Thus, by virtue of the foregoing processing, a printer can be controlled to utilize print heads having configura- 
tions not envisioned at the time of design, by use of commarvds from an external host processor that set parameters'for 
30 driving the print heads. As a consequence, tine flexibility of printer 30 to accept new print heads as they are developed 
with different head configurations arKJ other characteristics is greatiy increased. 

9.0. Print Buffer Operation 

35 [0347] Rgures 43-1 A tiirough 43-1 E Illustrate the transfer of print data from print data store 136 in host processor 23 
to print buffer 139 (depicted in Figures 10 and 1 1). for printing in a fonward direction. The print transfer in Figures 43-1 A 
through 43-1E is controlled by stored program codes in print driver 114 and by stored program codes in printer 30. In 
Figures 43-1 A through 43-1 E, a single print head 4330 performs scanning across a recording medium by ramping up 
from a stationary position to a uniform scanning speed In a forward direction, by scanning across the recording medium, 

40 and by ramping down from tiie uniform scanning speed to the stationary position. The ramp-up position is indicated by 
reference 4335, the scan area is indicated by reference 4338. and the ramp-down is indicated at 4339. Reference 
numeral 4320 represents an area in print buffer 139 in which is stored print data for the current scan. Areas 4321 are 
extra areas of the print buffer reserved for storage of print data oorresporKiing to the slant angle of the print head. (The 
need for extra storage In print buffer 139, so as to store data conresponding to the slant angles of the print nozzles, was 

45 described above in connection with Rgure 43D to 43F. with respect to the description in the preceding section concern- 
ing buffer readout order.) Reference numeral 4325 represents print data derived by printer driver 1 14 and stored in print 
data store 136 in host processor 23; The print data is for a next scan. Reference numeral 4315 represents a printed 
image on the recording medium, the printed image being stored in accordance with cunrent scan data in print buffer 
4320. 

50 [0348] As shown in Figure 43-1 A, there is print data for the current scan In all print positions of the print buffer, and 
there is print data for the next scan in all print positions of print data store 136. During the ramp-up period 4335. print 
head 4330 moves in the forward direction without any printing until it reaches a uniform scanning speed. Since there is 
no printing, there is no emptying of any print data in print buffer 4320 and tiiere is consequently no room in print buffer 
4320 so as to transfer print data for a next scan from print data store 136. 

55 [0349] Figure 43-1 B illustrates a situation in which print head 4330 has reached a scanning speed and has begun 
printout as illustrated at 4315. Since print data for the current scan has been emptied (or. more precisely. Is no longer 
needed since it has already been printed) from print buffer 4320. a first block of print data for a next scan can be trans- 
mitted from printer driver 1 14 from print data store 4325 to print buffer 4320. No further room is yet available in print 
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buffer 4320 for addrtional data from print data store 4325; accordingly, no further data is transmitted. 
[0350] One mechanism by which printer driver 114 determines that there is a vacant or empty area in printer buffer 
4320 is through use of a signal from printer 30 that indicates that data transfer to printer 30 can not currently be 
accepted. Examples of such a signal include a l3usy" signal or a "not-ready" signal or the like, and will hereinafter be 

5 referred to as a "busy signal". The busy signal is generated by printer 30 and transmitted over host computer interface 
141 to host processor 23. Specifically, since printer 30 utilizes a stepper motor for stepping its carriage across the 
recording medium, printer 30 at all times knows the print position of its print head 4330. Printer 30 further knov\^ the left 
and right edges of the cun^ently unprinted areas in printer buffer 4320. By comparison between the position of print head 
4330 and the left and right edges of print buffer 4320. printer 30 can determine whether there is an empty area in the 

10 print buffer into which to store data received from print driv^ 1 1 4. If there is no empty area in the print buffer, then printer 
30 generates a busy signal to host processor 23. On the other hand, if there is an empty area in the printer buffer 4320, 
then printer 30 clears the busy signal, indicating that it is ready to accept print data. 

[0351] In Figures 43-1 C through 43-1 E. more arxi more print data from the current scan is printed from print buffer 
4320 onto the recording medium, as signified at 4315. As each successive block of print data is emptied from buffer 

15 4320. print driver 114 transmits successive blocks of print data for a next scan from area 4325 of print data store 136 
to print buffer 4320. Thus, as shown in Figure 43-1 C, a second block of print data is transmitted from 4325 to 4320, in 
Figure 43- 1 D, successive blocks 3 through 8 are transmitted from print data store 4325 to print buffer 4320, and in Rg- 
ure 43-1 E. a sixteenth block of print data for a next scan is transmitted from print data store 4325 to print buffer 4320. 
In Figure 43-1 E. the entirety of a current scan has been printed, as signified at 4315, and print head 4330 begins its 

20 ramp-down operation. As will be appreciated. It is now possible for print head 4330 to begin printing in a reverse direc- 
tion, utilizing the print data for the next scan that has now been stored in print buffer 4320, during which print data for a 
further successive scan will be transmitted by printer driver 1 14 from print data store 136 to print buffer 139. 
[0352] Reverse printing is described as follows, in connection with Figures 43-2A through 43-2E. 
[0353] Specifically. Figure 43-2 A illustrates a situation like that in Figure 43-1 A, in which the size of the print data for 

25 a current scan (stored in print buffer 4320) is the same as or larger than the size of the print data for a subsequent scan 
(stored in print data store 4325). Reference numeral 4321 refers to extra storage of print buffer 4320 iso as to accom- 
modate the buffer readout order that compensates for slant angle of* nozzles on prirrt head 4330. Hereinafter, such an 
, area will be referred to as the "nozzle offset length"; Numeral 4315 refers to printed data already on the recording 
rnedium from a fonward scan. During a ramp-up period as signified at 4339. print head 4330 ramps-up from a stationary 

30 position to a uniform scanning speed; no data is printed and none is enrptied from print buffer 4320. In Figure 43-2B, 
print head .4330 is moving at a uniform speed in a reverse direction and has begun to print data corresponding to print 
data for a current scan In print buffer 4320. The printed data.on the recording medium is signified at 4316. Because a 
sufficientiy large area of print buffer 4320 has been emptied by printout on the recording medium, a first block of data 
from print data store 4325 is transferred by printer driver 1 1 4 to print Ixjffer 4320. 

35 [0354] With continued printing in the reverse direction, sut>sequent blocks of data are printed on the recording 
medium, thereby emptying print data from print buffer 4320. This situation is illustrated in Figures 43-2C and 43^20, in... 
which a second and subsequent blocks 3 through 8. are transferred by printer driver 114 from print data store 4325 into 
emptied areas of buffer 4320. As in the situation of Figure 43-1 , printer driver 114 transmits data to printer 30 so long 
as a busy signal is not received from printer 30. in Figure 43-2E, a final block of print data has been printed from print 

40 buffer 4320 onto recording medium at 4316, thereby permitting transfer of the final block of print data for the next scan 
from print data store 4325 to print buffer 4320. The. print fiead 4330 subsequently rampsrdown from the uniform scan- 
ning speed to a stationary position, as irxiicated at 4335. 

[0355] Figures 43-3A through 43-3F illustrate transfer of print data from print data store 136 in host processor 23 to 
print buffer 139 of printer 30, during a forward scan of a single print head 4330 across a recording medium, in a situation 

45 in which cun-ent print data stored in print buffer 4320 is smaller than the print data for a next scan as stored in print data 
store 4325 in host processor 23. Because the amount of current print data is smaller tfian the next print data, there are 
empty areas in print buffer 4320 even before printing has begun. It is therefore possitMe to take advantage of this situa- 
tion, by transferring print data for a next scan into the already-empty areas of prirrt buffer 4320. Such processing is 
explained below. In connection with Figures 43-3A through 43-3F. 

50 [0356] In this situation, print driver 1 14 does not need to rely exclusively on busy/ready signal generation from printer 
30, in order to determine whether there are empty spaces in the print buffer into which to store print data for a next scan, 
specifically, because it was tiie print driver that previously transmitted data for the current scan for storage into particular 
print buffer locations, the print driver can determine without any feedback from the printer exactiy which locations in the 
print buffer should be empty and ready to receive print data for a next scan. Printer 30 might generate a busy signal 

55 during print driver transmission of print data, but the busy signal would ordinarily be generated for reasons unrelated to 
the empty/full status of print buffer locations (e.g., the printer might not be ready to receive new data because it is occu- 
pied with other tasks such as head cleaning). 

[0357] In Rgure 43-3A, a single print head 4330 prints across a recording medium by ramping up from a stationary 
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position to a uniform scanning speed in area 4335, printing (or seeking in a fonward direction to a next print area) in a 
uniform speed across area 4338, and then ramping down from a uniform scanning speed to a stationary position at area 
4339. 4320 refers to a print buffer which includes areas 4320-1 . 4320-2, and 4320-3. of which only the latter area con- 
tains print data for a current scan. The remaining areas are empty, indicating that no data is to be printed at the corre- 

5 sponding locations on the recording medium. 4321 refers to the nozzle offset areas of print buffer 4320. 4325 refers to 
data for a next scan in print data store 136, as yet to be transmitted from host processor 23 to printer 30. 
[0358] In Figure 43-3B, during a ramp-up period of print head 4330, since there are empty locations in print buffer 
4320. a first block of information is transferred by printer driver 1 14 from print data store 4325 to print buffer 4320. Like- 
wise, in Figure 43-30, since print buffer 4320-2 is empty, a second block of print data is transmitted from print data store 

10 4325 to print buffer 4320. At this point, print head 4330 has reached its uniform scanning speed, and commences for- 
ward seeking to its first printing area corresponding to current print data in print buffer 4320. This situation is depicted 
at Figure 43-3D, in which printed data 4315 is printed by print head 4330 on the recording medium. Moreover, since 
printing of print data 431 5 empties the area in print buffer 4320. a subsequent block of print data is transferred by printer 
driver 114 from print data store 4325 to print buffer 4320. As print head 4330 continues to move in the forward direction. 

15 Figure 43-3E depicts the situation in which additional printed data is printed at 4315. and subsequent blocks of print 
data are transferred by printer driver 1 14 from print data store 4325 to print buffer 4320. In Figure 43-3F. print head 4330 
has completed printing of all current print data in print buffer 4320. as depicted at 4315, and is commencing fon^^ard 
seeking toward the erxJ of the next print data which at this point has all been transferred from print data store 4325 into 
print buffer 4320. When fonvard seeking is completed, print head 4330 ramps down in area 4339 from its uniform scan- 

20 ning speed to a stationary position, and commences ramp-up in a reverse direction to a uniform scanning speed for 
printing of print data now all stored in print buffer 4320: 

[0359] Reverse printing proceeds generally along the lines shown in Rgure 43-2. and involves transfer of next scan 
data into empty locations of print buffer 4320 during ramp-up, and sequential transfer of blocks of print data to the print 
buffer as print buffer locations are enptied during printout. 

25 

9.1 Single Print Buffer v >^ 

[0360] In the forward printing operation of Rgure 43-1 . and the reverse printing operation of Figure 43-2. since the 
amount of print data for a current scan is the same or larger than the amount of print data for a subsequent scan, it is 

30 not possible to transfer print data in advance from printer store 4325 to print buffer 4320. As a consequence, perform^ 
ance suffers since it is necessary to wait for the print head 4330 to empty data in the print buffer 4320 by printing before 
new data can be transmitted from printer driver 1 14 to printer 30. ^ t 

[0361] In contrast, in the situatiori of Figure 43-3, sincethe amount of print data for a current scan is smaller than the 
amount of print data for a subsequent scan, it is possitsle for printer driver 1 14 to transfer data for a subsequent scan to 

35 empty areas of print buffer 4320, even before print head 4330 begins printing. This arrangement provides advanta- 
geous processing speeds. At the same time, the situation where a current scan is smaller than a next scan occurs rel- 
atively infrequently, since it is much more ordinary for print data for each successive scan to be the same as, or 
approximately the same as. print data for a previous scan. ' 

[0362] To improve performance of print data transfer for all scans, the inventors herein have considered to provide an 
40 additional area In print buffer 4320 con-esponding to the ramp-up period of print head 4330, The additional area will 
hereinafter be referred to as the "shift area". Provision of an additional shift area for print buffer 4320 means that, for all 
times, even when print head 4330 is not printing, there will be empty areas in print buffer 4320 into which printer driver 
114 can deposit print data for a next scan. Particularly, j3rinter driver 114 can transfer print data into the shift area during 
or in advance of completion of ramp-up of print head 4330. Moreover, the print driver need not rely exclusively on the 
45 printer's generation of a busy/read signal to determine whether the printer is ready to accept print data to this shift area; 
because it is the print driver itself that designates where print data for a current scan and a next scan are stored in the 
print buffer, the print driver can determine whether the shift area is ready to receive print data, ordinarily without feed- 
back from the printer. 

[0363] Figures 43-4A through 43-4F illustrate use of a shift area to improve efficiency of data transfer, during a fonvard 
50 printing in a situation analogous to that illustrated in Figure 43-1 , that is. where print data for a current scan is approxi- 
mately the same size as that for a next scan: In Rgure 43-4A, print buffer 4320 includes a shift area 4320-1 which is 
appended at the forward most edge of area 4320-2. 4321 refers to areas in the print buffer that compensate for nozzle 
offset length. Region 4320-2 stores print data for a current scan, shift area 4320-1 is empty, and print data store 4325 
stores print data for a next scan that is awaiting transmission from printer driver 114. Unlike the illustration in Rgure 43- 
55 1 , print data for a next scan is illustrated in a shifted position from its actual print position, with the shift from its actual 
print position being indicated by dotted lines. The purpose for this shift is only for illustrative purposes so as to simplify 
illustration of transfer of data into the shift area 4320-1 and area 4320-2 of print buffer 4320. 

[0364] In the absence of a busy signal from printer 30. printer driver 114 determines that it is permissible to transmit 
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print data from print data store 4325 to print buffer 4320. Thus, as illustrated in Rgure 43-4B. during ramp-up period 
4335 of print head 4330, printer driver 1 14 transmits a first block of print Information for a next scan from print data store 
4325 to the shift area 4320-1 of print buffer 4320. After the shift area has been filled, printer 30 generates a busy signal 
which stops further transmission of data. In Rgure 43-4C. print head 4320 has reached a uniform scanning speed and 

5 commences printout of print data for a current scan by printing out data in area 4320-2 of print buffer 4320. Printing is 
illustrated at 4315. After an area of print buffer 4320-2 has been emptied, printer 30 releases the busy signal indicating 
to printer driver 114 that it is ready to receive additional data. As a consequence, printer driver 114 commences trans- 
mission of a second block of print data for a next scan from print data store 4325 to print buffer 4320. 
[0365] As print head 4330 continues printing in a forward direction, successive areas of print tHjffer 4320 are emptied 

10 of print data, thereby freeing those locations in print buffer 4320 for receiving print data for a next scan from print data 
store 4325. This situation is illustrated in Figures 43-4D and 43-4E In which successive areas of print buffer 4320 are 
emptied of print data by printout at 431 5, and successive blocks of print data are transmitted by printer driver 1 14 from 
print data store 4325 into prirrt buffer 4320. 

[0366] In Rgure 43-4E, a last block of print data for a next scan has been transmitted from print data store 4325 to 
IS print buffer 4320. However, printing for a current scan has not yet been completed, since print data for the current scan 
remains unprinted in print buffer 4320. Thus, as shown in Figure 43-4F, print head 4330 continues to print, freeing addi- 
tional area of print buffer 4320. The additionally freed area of print buffer 4320 is not needed for print data for a next 
scan, since all print data has already been transmitted as shown at Figure 43-4E. As a consequence, the newly-freed 
areas of print buffer 4320 are re-allocated into a shift area during reverse printing, which is shown in Figures 43-5A 
20 through 43-5F. In any event, at the conclusion of printing in the forward direction, print head 4330 ramps down from a 
uniform scanning speed to a stationary position, at 4339. 

[0367] Figures 43-5A through 43-5F illustrate transfer of print data from print data store 4325 for a next scan into print 
buffer 4320. which contains print data for a current scan in area 4320-2 as well as an empty shift area 4320-1 . Thus, 
printing illustrated in Figure 43-5 is similar to that illustrated in Figure 43-2. that is. printing in a reverse direction. How- 
25 ever, data transfer of Rgure 43-5 is different from data transfer illustrated in Rgure 43-2, primarily because of the use 
of shift area at 4320-1 which provides for more efficient data transfer. 

[0368] Before conclusion of ramp-up period of print head 4330 from a stationary position to a uniform scanning speed 
at ramp-up area 4335, since printer 30 has an empty area in its print buffer 4320, it indicates a ready signal to host com- 
puter 23. As a consequence, printer driver 1 14 transmits print data for a first block of a next scan from print data store 

30 4325 to shift area 4320-1. This is illustrated in Figure 43-5B, in which print head 4330 Is commencing its ramp-up to a 
uniform scanning speed. After print data for block 1 has been transmitted from print data store 4325 to shift area 4320- 
1 , printer 30 generates a txjsy signal indicating to printer driver 114 that no further print data is to be transmitted. 
[0369] In Figure 43-5C, print head 4330 has reached uniform scanning speed and has commenced printing in the 
reverse direction. Printout at 431 6 in the reverse direction has emptied an area in print buffer 4320. As a consequence, 

35 printer 30 generates a ready signal signifying to printer driver 114 that printer 30 can accept print data. Printer driver 
114 consequently transmits block 2 of print data for a next scan from print data store 4325 to print buffer 4320.. 
[0370] Figures 43-5D and 43-5E illustraite continued printing in the reverse direction. Thus, in Figure 43-5D. print head 
4330 continues printing In a reverse direction, thereby emptying print locations in print buffer 4320. In response to emp- 
tied print locations, printer driver 1 1 4 transmits print data for successive blocks of a next scan into successively emptied 

40 locations of print buffer 4320. In Figure 43-5E, a last block of print data for a next scan is being transmitted from print 
data store 4325 to print buffer 4320. However, printing in the reverse direction has not yet completed, since there are 
remaining unprinted data in print buffer 4320. Therefore, as illustrated in Figure 43-5F. printing continues in the reverse 
direction, emptying successive locations of print buffer 4320. The emptied locations are not needed for any print data 
for a next scan, since all such data was transmitted in Figure 43-5E. The emptied locations of print buffer 4320 therefore 

45 become a shift area for a succeeding printing in the forward direction. 

[0371 ] By virtue of the processing shown in Figure 43-4 and 43-5. transfer of print data is made more efficient by the 
use of a shift area in which tiie shift area is prefixed at a forward end of print buffer 4320 during a fonvaid print, and is 
created at the tail end of print buffer 4320 as a current line of print data is finished printing. The shift buffer created at 
the tail end of print buffer 4320 is used in a succeeding scan in a reverse print direction. As a consequence, since printer 

so driver 114 has empty locations of print buffer 4320 in which to transmit data during ramp-up of the print data, efficiency 
of print data transfer is increased. 

[0372] Figure 43-6 illustrates transfer of data in a situation similar to that of Figure 43-3 in the sense that the size of 
print data for a current scan is snr^ller than the size of print data for a next scan. However, in the data transfer illustrated 
in Figure 43-6, a shift area 4320-5 is provided corresponding to a ramp-up period of print head 4330, so as to increase 
55 efficiency of data transfer. 

[0373] In Figure 43-6. print buffer 4320 includes area 4320- 1 which contains print data for a current scan. Areas 4320- 
2, 4320-3 and 4320-4 are empty areas that do not contain print data. Areas 4321 are areas of print kxiffer 4320 provided 
for nozzle offset length. Area 4320-5 is a shift area corresponding to the ramp-up period of print head 4330. 
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[0374] As shewn in Figure 43-6A, print data for a next scan, which is currently stored in print data store 4325 In host 
processor 23, is larger than print data for a current scan. Accordingly, there are areas of print buffer 4320 that are empty 
and can accept data even though print head 4330 has not yet commenced printing. This situation is illustrated in Figure 
43-6B, which before completion of a ramp-up of print head 4330 from a stationary position to a uniform scanning speed, 

5 a first block of print data for a next scan is transmitted by printer driver 114 from print data store 4325 to print buffer 
4320. The print data is stored into shift area 4320-5 and empty area 4320-4. Thereafter, as shown in Figure 43-6C, print 
head 4330 has reached a uniform scanning speed and commences fonward seeking to the first printing position corre- 
sponding to print data in area 4320-1 of print buffer 4320. During this period, since there still remain empty areas in print 
buffer 4320, printer driver 114 transmits a second block of print data for a next scian from print data store 4325 into 

10 empty area 4320-2 of print buffer 4320. 

[0375] In Figure 43-6D, print head 4330 has reached the first print position and commences printout as shown at 
4315. As print head 4330 continues to print, it empties print data from print buffer 4320, thereby freeing those areas of 
print buffer 4320 to receive print data for a next scan. Thus, printer driver 114 transmits a third block of print data for a 
next scan from print data store 4325 to print buffer 4320. 

15 [0376] As print head 4330 continues to print in the fonward direction, it continues to empty storage locations in print 
t>uffer 4320. This situation is illustrated in Figure 43-6E in which print head 4320 has completed printing of all print infor- 
mation in a cunrent scan at 431 5. Printer driver 114 continues to transfer subsequent blocks of print data for a next scan 
into the emptied locations of print buffer 4320. At the same time, print head 4320 commences forward seeking to tiie 
first print position of the print data for the next scan. In Figure 43-6F, print head 4330 reaches tiiat position and begins 

20 ramp-down from a uniform scanning speed to a stationary speed so as to reverse scanning direction for reverse direc- 
tion printing. 

[0377] During ramp-ddwn and prior to ramp-up for reverse printing, area 4320-3 is now availat>le as an empty location 
for a shift area for reverse printing. As a consequence, even if print data for a next sequential scan is the same size or 
larger than tine print data stored in print buffer 4320, there is still empty locations in print buffer 4320 at area 4320-3 to 

25 accept print data for Vne next sequential scan. As a consequence, transmission of print data from printer driver 1 14 to 
print buffer 4320 is increased. .v ^- . 

[0378] Reverse printing proceeds generally along the lines shown in Rgure 43-2, and involves transfer of next s;can 
data into empty locations of print buffer 4320 during ramp-up, and sequential transfer of blocks of print data to the print 
buffer as print buffer locations are emptied during printout. 

30 [0379] In summary, use of a shift area so as to increase efficiency of transmitting print data involves cooperation 
between control on the printer driver and control on the printer side. On the printer driver side, ttie printer driver monitors 
the left and right edges for the current scan (which has previously been transmitted) and a next scan (which has yet to 
be transmitted). If the next scan's left edge is smaller than the current scan's left edge, then the printer driver sends a 
data block until tiie current scan's left edge has been reached. Likewise, rf the next scan's right edge is larger tiian the 

35 current scari's right edge, then the printer driver sends a data block for the right side of the next scan until the current 
scan*s right edge has been reached. This processing ensures that, in a situation where a next scan is larger than a cur- 
rent scan, data is transmitted as efficientiy as possible. 

[0380] In addition, for overlapping areas where a next scan's print area overlaps onto a current scan's print area, the 
printer driver divides the overlapping area into small blocks. In dependence on receipt of busy or ready signals from the 
40 printer, the printer driver transmits the overlapping areas in units of the small blocks. If the current scan is in a fbnivard 
direction, tiien tiie printer driver transmits the next scan's overlap data in small blocks from left to right; whereas if the 
cunrent scan is in a reverse direction, the printer driver sends the overlapping area of the next scan in small blocks from 
right to left 

[0381] On the printer side, when printing starts for a current scan, the printer maintains a monitor on the location of 
45 the print head. If the right edge of a received block of printer data is smaller than the current scan's left edge (as updated 
by the printer's monitor of can-iage movement), then the printer puts the received data t»lock into the print buffer imme- 
diately. Likewise, if the left edge of a received block of print data for a next scan is larger than the right edge of a current 
scan (as updated by tiie printer's monitor of carriage movement), then tiie printer puts the received data block into the 
print buffer immediately. For overlapped areas, that is. where a received block overlaps onto a current scan's print area, 
50 the printer issues a busy signal so as to stop transmission of any additional print data from the printer driver. When the 
block specified by the printer driver becomes vacant entirely, as updated by the printer's monitor of carriage movement, 
then the printer puts tiie received data block into tiie print buffer, and releases the busy signal so as to signify to tiie 
printer driver that the printer is ready to receive additional information. 

[0382] In any event, if a current scan is in the forward direction, then the printer prints commencing from the end of 
55 the shift area (as measured in tiie forward direction) of the print buffer, whereas, if the current scan is in the backward 
direction, tiien the printer prints commencing from the end of the shift area (as measured in the backward direction). 
[0383] These generalized procedures are illustrated in Figure 43-7, which illustrates printing by two print heads using 
two print buffers, each with a shift area, in a situation where current print data is smaller than print data for a next scan. 
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Printing illustrated in Figure 43-7 is for a forward direction, but as will be appreciated from the general guidelines out- 
lined above, printing and data transfer in a reverse direction proceeds conriplementarily. 

[0384] In Figure 43-7A, dual print heads 4330A and 4330B are displaced with a lateral distance 4340 therebetween, 
and are arranged to print in a uniform scanning speed from a stationary position, through a ramp-up period at 4335 to 

5 a uniform scanning speed, through a print area 4338 at a uniform scanning speed, and through a ramp<town period at 
4339 from the uniform scanning speed to the stationary position. One print buffer is provided for each print head, with 
print buffer 4320A being provided for print head 4330A. and with print buffer 4320B being provided for print head 4330B. 
Each print buffer includes print data for a current scan, with the size of print data for a next scan being larger than the 
size of print data for the current scan. Thus, for print buffer 4320A. print data for a current scan is stored in area 4320A- 

10 4, with empty areas 4320A-1 , 4320A-2 and 4320A-3 being empty. A shift area 4320A-5 prefixes print buffer 4320A so 
as to increase efficiency of data transfer. 4321 denotes storage locations for the nozzle offset length. 
[0385] Likewise, for print buffer 4320B. area 4320B-4 contains print data for a current scan. Areas 4320B-1 , 4320B- 
2 and 4320B-3 are empty. A shift area 4320B-5 precedes print buffer 4320B so as to increase the efficiency of data 
transmission to print buffer 4320B. and 4321 indicates storage locations for the nozzle offset 

IS [0386] At the host processor side, one print data store is provided for each print head. Thus, data store 4325A is pro- 
vided for print head 4330A and stores print data for a next scan; and print data store 4325B is provided for print head 
4330B and contains print data for a next scan for prirrt head 4330B. 

[0387] In Rgure 43-7B, print heads 4330 A and 4330B begin to ramp-up from a stationary position to a uniform scan- 
ning rate across a recording medium. Printer driver 114. in the absence of a busy signal from printer 30. determines 

20 based on prevfously transmitted print data that the left edge of next scan data for print head 4330A is smaller than the 
left edge for current print data, and consequently sends a first block of prirrt data from print data store 4325A to print 
buffer 4320 A, which is stored in shift area 4320A-5 and area 4320A-1. Likewise printer driver 1 14 determines that the 
left edge of next scan data for print head 4330B is smaller than the left edge of the current scan data for print head B. 
As a consequence, printer driver 114 transmits one block of print data for print head 4330B from prirrt data store 4325B 

25 to print buffer 4320B. The block of print data for the next scan is stored in shift area 4320B-5 and in area 4320B-1. 
[0388] In Figure 43-7C print heads 4330A and 4330B have reached their uniform scanning speed and commence 
forward seeking to the first print position for either of print head 4330A and 4330B. Printer 30 still has not sent a busy 
signal since empty areas remain in print buffers 4320A and 4320B and printer driver 114 has not sent data that overlaps 
onto existing print data for a current scan. Since printer driver 114 therefore concludes that printer 30 is ready to accept 

30 additional print data, it transmits print data appropriately. In this case, since the right edge of next scan data for print ■ 
head 4330A is larger^than the right edge of print data for a current scan, printer driver 114 transmits a block of print data . 
from print data store 4325A to print buffer 4320A. In this case, the transmitted data Is stored in area 4320A-2. Printer 
driver 1 14 may attempt to send new prirrt data for print head 4330 A. bUi since the transmitted data would overiap onto 
non-empty locations in the print buffer, any such transmission would cause the printer to generate the busy signal. At 

35 this point printer driver 114 determines that, for print head 4330A, the left edge for next scan is not smaller than the left 
edge for the current scan, and that the right edge for the next scan is not larger than the right edge for the current scan.^. 
Consequently, no print data for head 4330A is transmitted by the printer driver until the busy signal clears. 
[0389] On the other hand, printer driver 114 deta'mines that the right edge of next scan data for print head 4330B is 
larger than the right edge for print data for the current scan. Accordingly, a block of print data Is transmitted from print 

40 data store 4325B to print buffer 4320B. in this case, the block of transmitted data is. stored in area 4320B-2. Printer 
driver 114 may attempt to transmit additional print data for head 4330B, but since the transmitted data would overlap 
onto non-empty locations in the print buffer, any such transmissions would cause the printer to generate the busy signal. 
At this point printer driver 114 determines that, for print head 4330B. the left edge of the next scan print data is not . 
smaller than the left edge of the current scan print data, and that the right edge of the next scan print data is not larger 

45 than the right edge of the current scan print data. Consequently, no print data for head 4330B is transmitted to the print 
driver until the busy signal clears. 

[0390] At this point, no further data is transmitted from printer driver 114 to printer 30. If printer driver 114 were to 
transmit print data for either of print heads 4330A or 4330B. the printer driver would precede the data with an [EDGE] 
command which specifies to the printer the locations in the print buffer to which the succeeding block of print data 
50 shouki be stored. Based on the locations specified in the [EDGE] command, the printer would realize that any succeed- 
ing bfocks of print data from driver 114 woukl overiap onto non-empty locations in the print buffer, the printer thereupon 
issues the busy signal since any transmitted print data woukJ -unprinted print data, and printer 30 would is therefore not 
ready to receive additional print data. 

[0391] At Figure 43-7D, tiirough continued forward seeking of print heads 4330A and 4330B, print head 4330B has 
55 reached Its first print position. Accordingly, printout commences as indicated at 431 5B, thereby emptying locations in 
print buffer 4320B. Printer driver 1 1 4, which has divided the next scan's print area into small blocks, transmits a first one 
of the small blocks from print data store 4325B into print buffer 4320B. Printer 30, sensing that the buffer locations in 
4320B are empty based on the current location of print head 4330B. permits immediate storage of the transmitted 
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block. 

[0392] In Figure 43-7E. upon continued fonward printing of print head 4330B, additional locations in print buffer 4320B 
are emptied, thereby permitting transfer of data by printer driver 114 from print data store 4325B into print buffer 4320B. 
At the same time, print head 4330A has reached its first print position (more accurately, print head 4330A has reached 
5 the first print position in the nozzle offset area 4321 A). Printing therefore commences by print head 4330A, and contin- 
ues for print head 4330B' 

[0393] In Figure 43-7F, with continued printing by print head 4330B at 4315B. additional locations in print buffer 4320B 
are emptied. Printer driver 114 transntits additional blocks of print data for a next scan from print data store 4325B to 
print buffer 4320B. Since these locations are empty, printer 30 permits immediate storage of the transmitted blocks. 
10 [0394] In the meantime, print head 4330A has commenced printing as indicated at 4315A, thereby emptying locations 
in print buffer 4320A. As a consequence, printer driver 114 transmits a block of print data for a next scan from print data 
store 4325A to print buffer 4320A. Since the locations in print buffer 4320A are empty and do not contain overlapped 
data (as-yet-unprlnted data for a current scan), printer 30 allows the transmitted data to be stored immediately Into print 
buffer 4320A. 

15 [0395] At Rgures 43-7G and 43-7H, print heads 4330 A and 4330B continue printing, as indicated respectively at 
4315A and 4315B. With continued printing, additional locations in print buffers 4320A and 4320B are emptied. As a 
consequence, printer driver 114 transmits additional print data for a next scan from print data stores 4325A and 4325B, 
block-by-btbck. into empty locations of print buffers 4320A and 4320B, respectively. During this processing, and ail 
processing in which pririt data for a next scan is available for transmission from driver 114 to both heads, driver 114 

20 determines which head will have data transmitted first (i.e., A before B or B before A), the driver makes this determina- 
tion based on which head is nnore likely to empty a block first, based on the relative positions of the overlapped areas. 
This processing is described below In Figures 44C to 44J. which explains the procedure by which the driver decides 
whether to send blocks of print data for head A before B, or head B before A. 

[0396] In Figure 43-71, printing has concluded for print head 4330B, thereby emptying the last location for print buffer 
25 4320B. Accordingly, printer driver 114 transmits the last remaining block of print data for a next scan from print data 
store 4325B to print buffer 4320B. At the same time, printout for print head 4330A continues as indicated at 4315A, 
emptying additional locations in print buffer 4320A. As those locations are emptied, printer driver 114 transmits blocks 
of print data for a next scan from print data store 4325A to print buffer 4320Ai 

[0397] In Figures 43-7J and 43-7K, printing continues for print head 4330 A, emptying additional locations in prirrt 
30 buffer 4320A. As those locations are emptied, they are filled by print data for a next scan transmitted by driver 1 1 4 from 
print data store 4325A, block-by-block, to print buffer 4320A. In Figure 43-7K. printout of current print data for print head 
4330A Is completed, resulting in a last block being transmitted from print data store 4325A to print buffer 4320A. Heads 
4330 A and 4330B then commence forward seeking so as to reach the first print position for print data in the next scan. 
[0398] In Figure 43-7L, after print heads 4330A and 4330B have reached the first print position for reverse printing of 
35 the next scan line, the print heads ramp-down from the uniform scanning speed to a stationary position. At that time, 
areas 4320A-3 and 4320B-3 are empty locations in buffers 4320A and 4320B, respectively. These enpty areas there- 
fore become shift areas that receive print data for a next subsequent scan during a ramp-up period for reverse printing 
of the now-cunrent scan print data currently stored in print buffers 4320A and 4320B. 

40 9.2 General Description Of Buffer Control 

[0399] The flowcharts of Figures 44C through 44J illustrate the process steps performed by CPU 1 00 of host proces- 
sor 23 as part of execution of printer driver 1 14, so as to effect data transmission of print data for a next scan line from 
print data store 136 to print buffer 1 39. in accordance with the shift buffer control. The process steps Illustrated in these 
45 flowcharts are stored as computer executable process steps on a computer-readable medium such as disk 25 or in 
RAM 116, and executed by CPU 1 GO so as to effect shift buffer control. 

[0400] Likewise, the flowcharts of Figures 44K through 44M illustrate process steps performed by CPU 1 21 of printer 
30. so as to ieffe^ print buffer control. The process steps shown in these flowcharts are stored as computer executable 
process steps on a computer-readable medium such as ROM 122 or in RAM 129, for execution by CPU 121 so as to 
50 effect print control. 

[0401] In accordance with the process steps illustrated in these flow diagrams, print buffer control according to the 
invention defines a print buffer with a shift area prefixed to the print buffer, with the shift area corresponding to a ramp- 
up period in a fonn^ard direction of a print head. For reverse printing, the print buffer includes a shift area appended at 
the end thereof, with the shift buffer corresponding to the ramp-up period of the print head during reverse printing. The 
55 shift buffer for forward printing is part of the print buffer for reverse printing, and the shift buffer for reverse printing Is part 
of the print buffer for forward printing. 

[0402] By virtue of this arrangement. In which a shift buffer is appended or prefixed to a print buffer, a printer driver 
always has locations to transmit print data for a next scan line during a ramp-up period of the print head. Thus, efficiency 
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of transmitting print data for a next scan line from a printer driver to a printer is Increased. 

[0403] i^oreover, because the shift area corresponds to the ramp-up period, and because the shift buffer in the for- 
ward direction is part of the print buffer for printing in the reverse direction, and vice-versa» the increase in efficiency in 
print data transmission is obtained without the need to provide large amounts of additional print buffer locations, such 

5 as conventional double buffering arrangements. 

[0404] Before explaining the f bw diagrams of Figures 44C through 44J, and the flow diagrams of Rgures 44K through 
44M. Rgures 44A and 44B will be used to give an explanation of certain variables used in those f bw diagrams. These 
variables correspond to physical distances on printer 30, to storage locations within print buffers, and to the correspond- 
ence of storage locations within print buffers and their printout position on a recording medium. 

10 [0405] Rgure 44A provides variable Identifications for printing In the forward direction. Thus, for forward printing with 
print heads 4330A and 4330B using current print data in print buffers 4320A and 4320B, and with transmission of next 
scan print data from print data stores 4325A and 4325B. the following variables are defined: head gap 4340 defines the 
distance between heads 4330A and 4330B. head position A and head position B define the current carriage positions 
of heads A and B, respectively, BuffTop_F and BuffEnd_F define the top and the end of print buffers 4320A and 4320B 

IS for forward direction printing. EdgeL_Ac and EdgeR_Ac define the left and right edges of the current scan data for head 
4330A, EdgeL_Bc and EdgeR_Bc define the left and right edges of the current print data for print head 4330B, ShiftLen 
defines the length of the shift area, reference numeral 1203 defines the nozzle offset length so as to compensate for 
the slant angle of the nozzles in the print heads. EdgeL_An and EdgeR_An refer to the left and right edges of next scan 
data for print head 4330A. EdgeL_Bn and EdgeR_Bn define the left and right edges of next print data for head 4330B. 

20 BlockLen defines the width of blocks into which printer driver 1 1 4 divides next scan print data for transmission block-by- 
k)lock to print buffers 4320A and 4320B, and BlockLeft arxi BlockRight indicate the left and right addresses of an indi- 
vidual tAock currently being considered for transmission. 

[0406] Figure 44B identifies variables for printing by print heads 4330A and 4330B in a reverse (or iDackward") direc- 
tion. Thus, for t>ackward printing with print heads 4330A and 4330B using current prirrt data in print buffers 4320A and 

25 4320B, and with transmission of next scan print data from print data stores 4325A and 4325B. the following variables 
are defined: head gap 4340 defines the distance between heads 4330A and 4330B, head position A and head position 
B define the current carriage positions of heads A and B, respectively, BuffTop^B and Buff End_B define the top and the 
end of print buffers 4320A and 4320B for backward direction printing, EdgeL_Ac and EdgeR_Ac define the left and right 
edges of the current scan data for head 4330A, EdgeL_Bc and EdgeR_Bc define the left and right edges of the current 

30 print data for print head 4330B. ShiftLen defines ttie length of the shift area, reference numeral 1 203 defines the nozzle 
offset length so as to .compensate for the slant angle of tine nozzles in the print heads. EdgeL_An and EdgeR_An refer 
to the left and right edges of next scan data for print head 4330A, EdgeL_Bn and EdgeR_Bn define tiie left and right 
edges of next print data for head 4330B, BlockLeri defines the width of blocks Into which printer driver 114 divides next 
scan print data for transmission block-by-block to print buffers 4320A and 4320B, and BlockLeft and BlockRight indicate 

35 the left and right addresses of an individual block currently being considered for transmission. 

[0407] Representative exanrples of suitable values of the above-noted variables are as follows: 8 inches as the length . 
tor print buffers A and B, 1/2 inch as the lengtii as a. small data block, 2 1^ inches as tiie gap between head A and head 
B, 752 columns as the shift buffer area, and 32 columns for the nozzle offset length. The length of the current scan area 
and the next scan area depend upon the actual data being printed. For example, in connection with the example given 

40 at Figure 43-7, the length of current scan print data is approximately 3 inches, whereas the length of next scan print 
area is 8 inches. 

[0408] Referring now to the flowchart of Figures 44C through 44J, a detailed description will now be given of process- 
ing undertaken by printer driver 114 in accordance with stored program instructions sequences executed by CPU 100 
in host processor 23. 

45 [0409] Initially in step S4401 , a command from host processor 23 to printer 30 sets the next scan direction (forward 
or backward) and the edges of print data of the current scan are defined in step S4402. The left edge of the print data 
in print buffer A. EdgeL_A, is set to set to EdgeL_Ac (left edge of current scan print data) - nozzle-offset-lengtfi. The 
right edge of the print data in print buffer A, EdgeR_A. is set to EdgeR_Ac (right edge of print data in the current scan) 
+ nozzle-offset-length. The left edge of the print data in print buffer B, EdgeL_B, is set to set to EdgeL_Bc (left edge of 

so print data for the current scan) - nozzle-offset-length. The right edge of the print data in print buffer B, EdgeR_B» is set 
to EdgeR_Bc (right edge of current scan print data) -i- nozzle-offset-length. As aforementioned, the nozzle-offset-length 
corresponds to storage locations in a print buffer for an area corresponding to the slant of tiie nozzles on a print head. 
[041 0] In step S4404. printer driver 114 decides whether the current scan is forward or backward. For forward printing, 
flows advances to step S4405 which determines the printing direction of the next scan. If step S4405 determines that 

55 the print direction of the next scan is backwards, tiie edges EdgeL_A, EdgeL_B, EdgeR_A and EdgeR_B are adjusted 
in step 84406 by adding the length of the shift area corresponding to the storage locations of each print buffer to be 
filled during the ramp-up period. 

[041 1 ] Steps S4407 through S441 6 determine, for each of heads 4330A and 4330B, whether the next scan's left edge 
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is less than the current scan's left edge (meaning that empty areas exist in the left edge of the print buffer), and if so, 
transmit print data for the next scan from print data stores 4335A and/or 4335B to print buffers 4320A and/or 4320B. so 
as to fill up the left side of the buffer including the shift area when current printing is in a fbnward direction. Print buffer 
4320A is processed for left edge data transfer in steps S4407 through S4411. When it is determined that the left edge 

5 of print data for the next scan, EdgeL_An, is less than EdgeL_A corresponding to the current scan, a block select com- 
mand [BLOCK] and a data command [DATA] are sent to printer 30. The block select command is sent with a block left 
edge address of EdgeL_An (i.e., next scan left edge) and a block right edge address of EdgeL_A-1 (i.e., cunent scan 
left edge -1). The left edge of the next scan EdgeL_An is thereafter reset to Edge_A (S441 1). Flow then advances to 
process buffer 4320B for left edge data transmit availability. 

10 [041 2] It should be pointed out that the processing of all the steps in Figures 44C and 44D are designed so that printer 
driver 114 can determine which locations in printer 30's print buffer are empty, and transmit data to those empty loca- 
tions. It is therefore unlikely that printer 30 will issue a busy signal, which would signify that printer 30 is not prepared to 
accept data. However, if printer 30 does issue a busy signal (it may, for example, be involved in non-printing operations 
such as head cleaning or the like), then printer driver 114 stops transmitting data until the busy signal clears and printer 

15 30 is again ready to accept data. 

[041 3] Print buffer 4320B is then processed for left edge data transfer in steps S441 2 through S441 6. When it is deter- 
mined that the left edge of print data for the next scan. EdgeL_Bn. is less than EdgeL.B set for the current scan, a block 
select command [BLOCK] and a data command [DATA] are sent to printer 30. The block select command is sent with a 
block left edge address of EdgeL_Bn (i.e., next scan left edge) and a block right edge address of EdgeL_B-1 (i.e.. cur- 

20 rent scan left edge -1). The left edge of the next scan EdgeL_Bn is thereafter reset to EdgeL_B (S4416). 

[0414] Steps S4417 through S4426 determine, for each of print heads 4330A and 4330B, whether the next scan's 
right edge is greater tfian the current scan's right edge (meaning that empty areas exist in the right edge of the print- 
buffer), and if so, transmit print data for the next scan from print data stores 4325A and/or 4325B to print buffers 4320A 
. and/or 4320B, so as to fill up the right side of the buffer when cun-ent printing is in a forward direction. Print buffer 4320A 

25 is processed for right edge data transfer in steps S441 7 through S4421 . When it is determined that the right edge of 
print data for the next scan, EdgeR_An, is greater than EdgeR^A, a block select command [BLOCK] and a data com- 
mand [DATA] are sent to printer 30. The block select command is sent with a block left edge address of EdgeRiA-i-l 
(i.e.. currerrt scan right edge +1) and a block right edge address of EdgeR_An (i.e., next scan right edge). The block 
right edge of the next scan EdgeR_An is thereafter reset to EdgfeR_A (S4421). Flow then advances to process buffer 

30 4320 B for right edge data transmit availability. 

[0415] Print buffer 4320B is then processed for right iedge data transfer In steps S4425 through S4426. When it is 
determined that the right edge of print data for the next scan, EdgeR_Bn. is greater than EdgeR_B set for the current 
scan, a block select command [BLOCK] and a data command [DATA] are sent to printer 30. The block select command 
is sent with a block left edge address of EdgeR_B+1 (i.e:. current scan right edge) and a block right edge address of 

35 EdgeR_Bn (i.e.. next scan right edge). The right edge of the next scan EdgeR^Bn is thereafter reset to EdgeR_B 
(S4426). - .. . ^ . 

[041 61 The foregoing operations of steps S4405 through S4426 are performed during and before the ramp-up period 
of the print heads 4330A and 4330B. In accordance with the invention, it is determined where there are vacant storage 
locations in the print buffers 4320 A and 4320B and print data Is sent from print data store 136 of host processor 23 to 

40 the respective print buffers prior to the current scan of print positions of tiie buffers. 

[041 7] Steps S4427 through S4435 illustrate print data transfer during the current scan after transfer of data according 
to steps S4405 to S4426. Depending on speed of print data transfer, portions of these steps might actually be per- 
formed during the ramp-up period, if data transfer in steps 84405 to 84426 is completed before the end of the ranp-up 
period. These steps determine whether there is overlapped data only in buffer 4320A, only in buffer 4320B. or in both 

45 buffers 4320 A and 4320B. In a case where there is overlap In both of buffers 4320 A and 4320B, these steps further 
determine whether data for buffer 4320A should precede that for buffer 4320B. or vice-versa. 
[0418] The steps illustrated at Rgures 44E and 44F are executed at a time when it is likely that there wilt be an overlap 
between data transmitted by the printer driver 114 and as-yet-unprinted data in printer buffer 139. Accordingly, trans- 
mission of data by printer driver 1 1 4 Is conditional on the busy signal from printer 30. If there is a busy signal then printer 

50 driver 114 stops transmission of data urrtil the busy signal clears and printer 30 Is again ready to accept new print data. 
[0419] Thus, in steps S4427 and S4429. printer driver 1 14 tests whether EdgeL^An for the next scan is less than 
EdgeR_An for the next scan but EdgeL_Bn for the next scan is not less than EdgeR_Bn for the next scan. If these con- 
ditions are met, there is overlapped data only In buffer 4320A. Consequently, one predetermined small block of print 
data for print buffer 4320A Is sent from the left block to the right block addresses of the block to print buffer 4320 A (step 

55 S4431 ; see Figure 44G). Step 84427 Is then reentered for transfer of the print data of the next small block transfer. 
[0420] In steps 84427 and S4432. printer driver 114 tests whether EdgeL_An for the next scan is not less than 
EdgeR_An for the next scan but that EdgeL_Bn for the next scan is less than EdgeR_Bn for the next scan. If these con- 
ditions are met, there is overlapped data only in buffer 4320B. Consequently, one predetermined small block of print 
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data for print txjffer 4230B is sent from the left to the right addresses of the block to print buffer 4320B (step 84434; see 
Figure 44H). Step S4427 is then reentered for transfer of the print data of the next small block transfer. 
[0421 ] In steps S4427 and S4429. printer driver 114 also determines whether EdgeL_An for the n^ scan is less than 
EdgeR_An for the next scan and that EdgeL_Bn for the next scan is less than EdgeR.Bn for the next scan. If these con- 
5 ditions are met. there is overlapped data in both buffers 4320A and 4320B. Step S4430 then determines whether data 
for buffer 4320A precedes that for buffer 4320B or vice-versa. 

[0422] Specifically, step S4430 decides whether EdgeL_Bn is greater than or equal to EdgeL_An + the gap between 
print heads 4330A and 4330B. If so, data for buffer 4320A precedes that for buffer 4320B. Consequently, a small pre- 
determined print data block for print buffer 4320A is sent to print buffer 4320 A from print data store 136 of host proces- 

10 sor 23 (step S4431). On the other hand, a "NO" decision in step S4430 indicates that data for buffer 4320B precedes 
that for buffer 4320A. Consequently, a small predetermined print data block for print buffer 4320B is sent to print buffer 
4320B from print data store 136 of host processor 23 (step S4434) and control is returned to step S4427. 
[0423] When it is decided in steps S4427 and S4432 that EdgeL_An is not less than EdgeR_An and that EdgeL_Bn 
is not less than EdgeR_Bn, the data transfer is complete and a print command [PRINT] for the next scan line is sent to 

15 printer 30 in step S4435. 

[0424] Referring again to Figure 44C. when step S4404 decides that the current scan is backward, step 84445 deter- 
mines the printing direction of the next scan. If step S4445 determines that the nest scan is fonward, the edges 
EdgeL_A, EdgeL_B, EdgeR_A and EdgeR_B are adjusted in step 84446 by subtracting the length of the shift area for 
storage locations of each print buffer to be filled during the ramp-up period. 

20 [0425] Steps S4447 through 84466 determine, for each print heads 4330A and 4330B, whether the next scan's right 
edge is greater than the current scan's right edge (meaning that empty areas exist in the right edge of the print buffer), 
and if so, transmit print data for the next scan from print data store 4325A and/or 4325B to print buffers 4320A and/or 
4320B, SO as to fill up the right side of buffers 4320A and/or 4320B including the shift area when the current printing is 
, in a reverse direction. Print buffer 4320A is processed for right edge data transfer in steps S4447 through 84451 . When 

25 it is determiried that the right edge of print data for the next scan. EdgeR_An, is greater than Edge R_A corresponding 
to the current scan (step S4447), a block select command [BLOCK] and a data command [DATA] are sent to printer 30. 
The block select command is sent with a block left edge address of EdgeR_A^1 (i.e., current scan right edge +1 } and 
a block right edge address of EdgeR__An (i.e. , next scan right edge)..The right edge of the next scan EdgeR_An is.then 
reset to Edge R_A (step 84451). 

30 [0426] Print buffer 4320B is then processed for right edge print data transfer in steps 84452 through 84456. When it 
is determined that the; right edge of print data for the next scan, EdgeR_Bn, is greater than EdgeR_B corresponding to 
the current scan, a block select command [BLOCK] and a data commarKi [DATA] arje sent to printer 30. The block select 
command is sent with a block left edge address of EdgeR_B+1 (i e.. current scan right edge +1) and a block right edge 
. address of EdgeR_Bn (i.e., next scan right edge). The right edge of the next scan, EdgeR_Bn, is then reset to EdgeR_B 

35 (step 84456). 

[0427] Steps S4459 through 84456 determinie, for each of heads 4330A and 4330B, whether the next scan's left edge 
is less than the current scan's left edge (meaning that empty areas exist in the left edge of print data stores 4325A 
and/or 4325B to print buffers 4320A and/or 4320B), so as to fill up the left side of buffers 4320A and/or 4320B when 
current printing is in a reverse direction. Print buffer A is processed for left edge print data transfer in steps 84457 

40 through 84461 . When it is determined that the left edge of print data for the next scan, EdgeL_An, is.less than EdgeL_A 
corresponding to the current scan (step 84457), a t>lock select command [BLOCK] and a data command [DATA] are 
sent to printer 30. The block select command is sent with a block left edge address of EdgeL_An (i e., next scan left 
edge) and a block right edge address of EdgeL_A-1 (i.e., current scan left edge-1). The left edge of the next scan, 
EdgeL_An, is then reset to EdgeL_A (step 84461). 

45 [0428] Print buffer 4320B is then processed for left edge print data transfer in steps 84462 through 84466. When it is 
determined that the left edge of print data for the next scan, EdgeL_Bn, is less than EdgeL_B corresponding to the cur- 
rent scan, a block select command [BLOCK] and a data command [DATA] are sent to printer 30. The block select com- 
mand is sent with a block left edge address of EdgeL_Bn (i.e., next scan left edge) and a block right edge address of 
EdgeL_B-1 (i.e.. current scan left edge-1). The left edge of the next scan, EdgeL^Bn. is then reset to EdgeL_B (step 

50 84466). 

[0429] The foregoing steps are executed during and before ramp-up of heads 4330A and 4330B. Steps 84467 
through 84475 illustrate data processing during the current scan after transfer of data according to steps 84445 to 
84466. Depending on the speed of print data transfer, portions of these steps might actually be performed during the 
ramp-up period, if data transfer in steps 84445 to 84466 is conpleted before the end of the ramp-up period. These 
55 steps determine whether there is overiapped data only in buffer 4320A, only in buffer 4320B, or in both buffers 4320A 
and 4320B. In a case there is overlap in both of buffers 4320A and 4320B, these steps further determine whether data 
for buffer 4320A should precede that for buffer 4320B, or vice-versa. 

[0430] Thus, in steps 84467 and S4469. printer driver 114 tests whether EdgeL_An for the next scan is less than 
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EdgeR_An for the next scan but EdgeL_Bn for the next scan is not less than EdgeR_Bn for the next scan. If these con- 
ditions are met, there is overlapped data in buffer 4320A only. Consequently, one predetermined small block of print 
data for print buffer 4320A is serrt from the left block to the right block addresses of the block to print buffer 4320A (step 
S4471, see Figure 441). Step S4467 is then reentered for transfer of the print data of the next small block transfer. 

5 [0431] In steps S4467 and S4472, printer driver 114 tests whether EdgeL_An for the next scan is not less than 
EdgeR_An for the next scan but that EdgeL_Bn for the next scan is less than EdgeR_Bn for the next scan. If these con- 
ditions are met. there is overlapped data in buffer 4320B only. Consequently, one predetermined small block of print 
data for print buffer 4320B is sent from the left to the right addresses of the block to print buffer 4320B (step S4474; see 
Rgure 44J). S4467 Is then reentered for transfer of the print data of the next small block transfer. 

10 [0432] In steps S4467 and S4469, printer driver 1 1 4 also determines whether EdgeL_An for the next scan is less than 
EdgeR_An for the next scan and that EdgeL_Bn for the next scan is less than EdgeR_Bn for the next scan. If these con- 
ditions are met. there is overlapped data in both buffer 4320A and 4320B. Step S4470 then determines whether data 
for buffer 4320A precedes that for buffer 4320B, or vice-versa. 

[0433] Specifically, step S4470 decides whether EdgeR_Bn minus the gap between prirrt heads 4330A and 4330B is 
IS less than or equal to EdgeR_An. If so. data for buffer 4320A precedes that for buffer 4320B. Consequently, a small pre- 
determined print data block for print buffer 4320A is sent to print buffer 4320A from print data store 136 of host proces- 
sor 23(step 84471). K a "NO" decision is reached in step S4470. data for buffer 4320B precedes that for buffer 4320A. 
Consequently; a small predetermined print data block for print buffer 4320B is sent to print buffer 4320B from print data 
store 136 of host processor 23 (step S4474) and control is returned to step S4467. 
20 [0434] When it is decided in steps S4467 and S4472 that EdgeL_An is not less than EdgeR_An and that EdgeL_Bn 
is not less than EdgeR_Bn. the data transfer is complete and a print command [PRINT] for the next scan line is sent to 
printer 30 in step S4475. 

[0435] Figures 44G and 44H show detailed flowcharts of the steps 84431 and 84434 of Figure 44E for a left block to 
right block addressed print data transfer for print buffers 4320A and 4320B. Referring to Figure 44G with respect to print 

25 buffer 4320A. EdgeL_A is set to EdgeL__An for the next scan plus the predetermined small block length in step S4476. 
Step 84477 is then entered wherein it is decided whether EdgeR_An for the next scan is less than EdgeL_A. If '^ES", 
a block command is sent to print buffer 4320A with a left block address of EdgeL_An and a right block address of 
EdgeR_An (step 84478), print data so addressed Is sent to print buffer 4320A (84479) and the left edge of the' hext 
scan print data. EdgeL_An. is set to EdgeR_An (84480). If "NO" in step 84477. a block command is sent to print buffer 

30 4320A with a left block address of EdgeL^An arxl a right block address of EdgeR_A-1 (step S4481). print data so 
addressed is sent to print buffer 4320A (84482) and the left edge, EdgeL_An, of the next scan print data is setvto 
EdgeLA (step 84483): c^:U= 
[0436] Figure 44H shows a detailed flowchart of step 84434 of Rgure 44E for a left block to right block addressed 
print data transfer for print buffer 4320B. Referring to Figure 44H. EdgeL_B is set to EdgeL_Bn for the next scan plus 

35 the predetermined small block length in step S4486. Step 84487 is then entered wherein it is decided whether 
EdgeR_Bn for the next scan is less than EdgeL_B. If 'YES", a block command is sent to print buffer 4320B with a left 
block address of EdgeL^Bn and a right block address of EdgeR_Bn (step 84488), print data so addressed is sent to 
print buffer 4320B (84489) and the left edge of the next scan print data, EdgeL_Bn, is set to EdgeR.Bn (84490): If "NO" 
in step 84487, a block command is sent to print buffer 4320B with a left block address of EdgeL,Bn and a right block 

40 address of EdgeL_B-1 (step 84491), print data so addressed is sent to print buffer 4320B (84492) and the left edge. . 
EdgeL_Bn. of the next scan print data is set to EdgeL_B (step 84493). 

[0437] Figures 441 and 44J show detailed flowcharts of the steps 84471 and 84474 of Rgure 44F for a right block to 
left block addressed print data transfer for print buffer 4320A. Referring to Figure 441 with respect to print buffer 4320A, 
EdgeR_A is set to EdgeR_An for the next scan minus the predetermined small block length in step 84506. Step 84507 

45 is then entered wherein it is decided whether EdgeL_An for the next scan is less than EdgeR_A. If "YES", a block com- 
mand is sent to print buffer 4320A with a left block address of EdgeL_An and a right block address of EdgeR__An (step 
84508). print data so addressed is sent to print buffer 4320A (84509) and the right edge of the next scan print data. 
EdgeR_An, is set to EdgeL_An (84510). If "NO" in step 84507, a block command is sent to print buffer 4320A with a 
left block address of EdgeR_A+1 and a right block address of EdgeR_An (st^ 8451 1). print data so addressed is sent 

50 to print buffer 4320A (8451 2) and the right edge of the next scan print data. EdgeR_An is set to EdgeR_A (step 8451 3). 
[0438] Figure 44J shows a detailed flowchart of step 84474 of Figure 44F for a right block to left block addressed print 
data transfer for print buffer 4320B. Referring to Figure 44J, EdgeR.B is set to EdgeR_Bn for the next scan minus the 
predetermined small block length in step 84516. Step 8451 7 is then entered wherein it Is decided whether EdgeL_Bn 
for the next scan is less than EdgeR__B. If "YES", a block command is sent to print buffer 4320B with a left block address 

55 of EdgeL_Bn and a right block address of EdgeR_Bn (step S451 8), print data so addressed is sent to print buffer 4320B 
(84519) and the left edge of the next scan print data, EdgeR_Bn. is set to EdgeL_Bn (S4520). If "NO" in step 8451 7, a 
t>lock command is sent to print buffer 4320B with a left block address of EdgeR_B-f1 and a right block address of 
EdgeR.Bn (step 84521), print data so addressed is sent to print buffer 4320B (84522) and the right edge of the next 
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scan print data. EdgeR_Bn. is set to EdgeR_B (step S4523). 

[0439] Figures 44K through 44M are flowcharts showing the processing In printer 30 for print data transfer which cor- 
respond to stored computer executable program codes residing in ROM 122 of printer 30. In general, these steps pro- 
vide for printer operation as follows: (1) When the current scan's printing starts, the printer monitors the position of the 

5 carriage and of carriage movement; (2) If the right edge of a received block is smaller than the current scan's left edge, 
then put the data block into the printer buffer immediately. If the left edge of a received block Is larger than the current 
scan's right edge, then put the data block into the printer buffer irhmediateiy; (3) If the block which is specified by the 
printer driver is overlapping on current scan's printer area, then issue a busy signal so as to cause the printer driver to 
wait until the specified block become vacant entirely If the block which is specified by the printer driver becomes vacant 

10 entirely, then put the data block into the printer buffer and release any busy signal so as to signify to the printer driver 
that the printer is ready to accept data; and (4) if the current scan is forward direction, then the printer prints shifted 
buffer. If the current scan is backward direction, then printer prints the non-shifted buffer. Referring to Figure 44K, deci- 
sion steps S4545, S4548. S4550, S4553 and others, indicated by a dashed line, are sequentially performed when a 
command from printer driver 114 is received in step S4544. If the received command is determined to be a direction 

15 command in step S4545, the next scan direction (i.e., fonward or backward) is received (step S4546), tiie current scan 
and next scan directions are set (step 84547) and control is passed to step S4548. When the command received in step 
S4544 is detected as a block command in step S4548, the block address processing of step S4549 is performed. The 
block address processing will be described in greater detail with respect to Figures 44L and 44M. 
[0440] When the received command In step S4544 is decided to be a data command in step S4550. print data 

20 received in step S4551 is put into tiie designated print buffer (step S4552) and control is passed to step S4553 wherein 
whether the received command in step S4554 is a print command is determined, tf '*YES" in step 84553, It is then deter- 
mined In step S4554 whether the current scan has been set to the forward direction. When the set current scan direc- 
tion is the forward direction, printing is executed from the top of the designated print buffer which corresponds to tiie first 
print position of a print head after the shift area to the opposite end of tiie designated print buffer (step S4555). For a 

25 backward direction scan, printing Is executed from the other end of the print buffer which corresponds to the last print 
position of the print head to the top of the designated buffer. Control is then returned to step 84544 to await another 
command from printer driver 114. = - 

[0441] Rgures 44L and 44M show the block address processing of step 84549 of Figure 44K is greater detail. Refer- 
ring to Figure 44L, the Wock left and block right addresses in the block command are received In step 84534 and it Is 

30 decided in step S4535 whetiier print data of the current scan remains in the designated print buffer. If tiie print buffer 
does not have remainirig current scan print data in step 84535. control is passed to step 84550 in Figure 44K to deter- 
mine if a data command has been received. Otfierwise. it is determined in step 84536 whetiier the designated print 
buffer is print buffer A or print buffer B. a variable X is appropriately set to A or B in one of steps 84537 and 84538, and 
control is passed to step 84539. In step 84539. the left edge of the designated print buffer X, Edge_X, Is set to the 

35 EdgeL_Xc (i.e.. the left edge of print data for the current scan in the designated buffer) minus the nozzle offset length, 
where no prirrting can occur. The right edge of the designated buffer, EdgeR_X is set to EdgeR_^Xc (i.e.. right edge of ^ 
print data for the current scan in tiie designated buffer) plus the nozzle offset length, where no printing can occur. Con- 
trol is then passed to step 84540 in which the current scan direction is checked. 

[0442] When the current scan direction in step 84540 Is the forward direction, the left and right edges of the desig- 
40 nated print buffer are set to provide shifting of the print data of the next scan. Accordingly, In step S4541 the left edge 
EdgeL_X is set to EdgeL_X plus the shift area length and the right.edge EdgeR_X is set to EdgeR_X plus the shift area 
length. When the current scan direction is the backward direction, no adjustment is needed since there are no prede- 
fined shift areas at the bottom ends of the print buffers. The next scan direction is checked in step 84542- H the scan 
direction is the forward direction in Step 84542, step S4543 is executed wherein the block left and block right 
45 addresses. BlockLeft and BlockRight. are set to BlockLeft plus the shift area length and BlockRight plus the shift area 
length, respectively, to account for shifting of the next scan print data when inserted into the designated print buffer X. 
[0443] 8tep 84525 of Figure 44M is then entered from step S4543 through connection 10-11. In decision steps 84525 
and S4526, it is determined if the BlockRight address is less than EdgeL_X (i.e.. the left edge of print data in the print 
buffer X) or if the BlockLeft address is greater than EdgeR_X (I.e., the right edge of print data in tiie print buffer X). If 
50 either of tiiese conditions Is true, the block of print data of the next scan to be transferred to the print buffer is outside 
the area of the print buffer X containing print data so that an immediate transfer can be performed and control is 
returned to step 84550 of Figure 44K for data command processing. 

[0444] When tiiere are "NO" decisions in both steps 84525 and 84526, there is overlap of next scan print data and 
the current scan print data in the print buffer X arxJ step 84527 is entered wherein it Is determined If the current scan 
55 direction is the forward direction. If there is a "YES" decision in step 84527, it is determined whether the BlockRight 
address is less than or equal to EdgeR_X (84528). Responsive to a "YES" decision in step 84528, the return to step 
84550 of Figure 44K for data comnnand is delayed until the BlockRight address is less than HeadPos_X (step 84529} 
which is the position of the print head associated with print buffer X. so as to assure inserting the block print data, into 
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a vacated area of the print buffer X. Responsive to a "NO** decision in step S4528. return to step S4550 of Figure 44K 
Is delayed until the print head for the print buffer X is finished printing the current print position (step S4530). 
[0445] Responsive to a backward direction cun'ent scan in step S4527, step S4531 is entered in which it is determined 
whether the BlockLeft address is greater than or equal to EdgeL_X (S4531). Responsive to a "YES" decision in step 
5 S4531 , the return to step S4550 of Figure 44K for data command is delayed until the BlockLeft address is greater than 
HeadPos_X (step S4532) so as to assure inserting the block print data into a vacated area of the print buffer X. Respon- 
sive to a "NO" decision in step S4531 , return to step S4550 of Figure 44K is delayed until the print head for the print 
buffer X is finished printing the current print position (step S4533). 

[0446] In accordance with the invention, the transfer of print data for a next scan from host processor 23 to print buffer 
10 139 during the current scan obviates the need for a separate receiving buffer of the same size as print buffer 139 and 
increases the efficiency of print data transfer. Further, the size of the shift area is not fixed but is set by the 
[DEFINE_BUF] command for each printing task so that the shift area size may be selected according to the storage 
capacity of printer 30. 

[0447] Moreover, printer buffer shift area technology can be applied in the transfer of any data between any top proc- 
15 essors. Rgure 44N illustrates at 850 the embodiment described here in which shift buffer technology is applied to trans- 
fer print data between a printer driver and a printer controller. 860 illustrates that shift buffer technology can also be 
applied to transfer print data between a pririt controller and a print engine. 

10.0 Multi-Head Printing With Differing Resolutions 

20 

[0448] Because printer 30 has multiple print heads, and because of software architecture in which commands affect- 
ing resolution are sent to each print head independently, printer 30 can print and can be corrtrolled to print with differing 
resolutions for each print head so as to increase overall print efficiency in situations where print data for one page 
includes print information for which a higher resolution is desired mixed with print data for which a lower resolution is 
25 adequate. 

[0449] Generally speaking, this section describes control over a printer having at least first arxi second print heads 
such that the resolutbn of the first and second print heads is controlled independently of each other' As described 
above tn section 1.0. printer 30 includes two ink jet print heads A and B, designated 130a and 130b. respectively; and 
as described in section 3.0, the software architecture includes commands sent from host processor 23 that affects print 

30 resolution. Printing is effected by transmission of image data from host processor 23 to print buffer 139 in printer 30 
(using the [DATA] command), and subsequent transrnission of the [PRINT] print execution command. Control over print 
resolution Is effected by transmission of commands which change ink droplet size (the [DROP] command), commands 
which select print speed (the [SPEED] command), commands which select nozzle firing order (the [SELECT_PULSE] 
command), and commands that select the readout order for reading out image data from printer buffer 139 (the 

35 [SELECT_CONTROL] command). 

[0450] The resolution with which each print head prints may be determined manually by user input, or automatically 
based, for example, on relative head cortfiguratk>n for print heads 130a and 130b. content of print data, and type of 
recording (or print) media. A user interface in printer driver 1 1 4 is provided for this purpose. 

[0451 ] From the perspective of the printer, printer 30 receives commands to set resolution for each of print heads 1 30a 

40 and 130b independently, and effects printout at the selected resolution. 

[0452] Figure 45 is a representational view for explaining the benefits of printout with different resolutions for each of 
different heads. In Figure 45, 400 depicts a printed sheet on recording media 401 virtiich contains mixed print informa- 
tion of different types. Areas 402a. 402b. 402c and 402d are text areas consisting of primarily black and white areas, 
for which a low resolution is adequate. Area 404. on the other hand, represents a non-text area, such as a color image 

45 or graphic or line drawing, for which a high resolution is desired. Thus, as can be seen in Figure 45. printout 400 con- 
sists of mixed print information, some of which is desired to be printed at high resolution, whereas others of which low 
resolution is adequate. The print information is mixed on a single recording medium 401. and in some cases, such as 
area 404 and 402b. is mixed across a horizontal print band in the scan direction of printer 30. 

[0453] 405 is an enlarged view of a portion of area 402a. Enlarged view 405 depicts print heads 1 30a and 1 30b which 
so differ in configuration. Specifically, print head 130a includes yellow, magenta, cyan and t>lack print nozzles arranged 
vertically with 24 nozzles for yellow, 24 nozzles for magenta. 24 nozzles for cyan and 64 nozzles for black. Print head 
130b includes 128 print nozzles for black ink only. Thus, print heads 130a and 130b differ in configuration, with print 
head 130a being adapted to print high resolution color images, whereas print head 130b is adapted to print black and 
white Images only. Of course, other configurations for heads 130a and 130b are possible so as to result in a situation 
55 in which one print head is adapted to print high resolution images whereas the other is adapted to print lower resolution 
images. 

[0454] Because area 402a is a text area for which low resolution is adequate, printing of area 402 is effected by print 
head 130b. This arrangement is shown at 405 in which one band 406 from print head 130b is depicted in cross-hatched 
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emphasis. To print at this resolution, printer 30 Is commanded to put print head 130b into a large droplet ejection mode, 
and print data readout order from print buffer 139 is selected In accordance with the head configuration of print head 
1 30b and in accordance with the selected resolution. These steps are described more fully below In connection with the 
flowchart of Figure 45A. 

5 [0455] In contrast to area 402a. area 404 is an area for which high-resolution printout is desired. This situation is 
depicted in the enlarged area at 407 which shows printout by print head 1 30a only at band 409. As described more fully 
below In connection with the flowchart of Figure 45A, to effect printout in the band shown at 409, print head 130a is 
commanded to eject ink in small droplets, and the data readout order from print buffer 139 is selected In accordance 
with the head configuration of print head 130a and the selected resolution. 

10 [0456] To print areas like 402b, which are mixed laterally in the direction of a scan of print heads 130a and 130b 
across recording media 401 , a two-step procedure is employed. In one step, sequential bands like 409 are printed by 
print head 130a. The number of sequential bands printed corresponds to the ratio between the number of print nozzles 
in a band for print head 130a and the number of nozzles in a band for print head 130b. In the other step, a single pass 
from print head 130b is effected in area 402b. By virtue of this two-step process, recording media 401 can be advanced 

IS in a single direction continuously, without requiring reverse feed, so as to effect printout of area 402b. 

[0457] Rgure 45A is a flow diagram showing process steps executed by printer driver 114 in host processor 23 so as 
to control print resolution for each print head independently, and to command pnntout to be effectuated thereby Gen- 
erally speaking, the process steps shown in Figure 45A are stored program instruction sequences that set print resolu- 
tion by controlling ink droplet size for each head independently, and by controlling readout order from print buffer 139 

20 for each print head independently. 

[0458] More specifically, in step S4501 . a user of host processor 23 issues a command from an application to print 
print data, thereby actuating printer driver 1 14. Printer driver 114 actually performs many more functions than indicated 
in the remainder of Figure 45. but only those functions having some bearing on setting of print resolution independently 
are described. Thus, in step S4502, printer driver 1 1 4 determines whether print resolution should be designated auto- 

25 matically by printer driver 114. or whether the print resolution shoukJ be designated manually by the user. In step 
84502, a user interfece is displayed to the user, such as the representative user interface shown in Figure 46. As seen 
there, section 410. when selected by the user, provides for automatic designation of print resolution. On the other hand, 
when 41 1 is selected; the user manually designates print resolution. Separate resolutions may be specified for non-text 
graphics as well as for text, with the user being able to designate manually either high speed (i.e., low resolution) or high 

30 quality (i.e., high resolution) for each of t©rt and npn-text regions. 

. [0459] Reverting to 'Figure 45. if automatic designation has been selected, then flow branches to step S4504 in which 
printer driver 114 automatically selects resolution for graphics, and then to step S4505 in which printer driver 114 auto- 
matically selects resolution for text. Selection of resolution for graphics and for text is based on continuous-tone print 
data, and is made in accordance with the presence of graphics and other non-text information, the presence of text 

35 information, the type of recording media selected for printout and the relative print head configurations of print head 

130aandprint head 130b. 

[0460] Row next advances to step 84506 in wNch the printer driver determines whether dual resolutions have been 
specified, either manually or automatically. If no dual resolutions have been specified, then flow branches to step S4507 
to proceed with printing in a uniform resolution for txsth heads. On the other hand, if dual resolutions have been sped- 

40 f ied, then flow advances to step 84509 so as to control print resolution of each print head independently and to. effect 
printout thereby. 

[0461] Thus, step 84509 defines buffer control tables, one of which is selectable for each head and by which each 
print head can determine readout order for readout of print data from its respective print buffer. Actual selection of which 
buffer control table to use is not effectuated until later in the procedure, but step 84509 merely defines suitable buffer 
45 control tables for each resolution and for each direction of printout. Preferably, the define buffer control table command 
[DEFINE_CONTROL] described above in section 3.6 is used- 

[0462] Likewise, step 84510 defines suitable heat pulse tables by which the firing sequence for each nozzle in print 
heads 130a and 130b is controlled. The actual heat pulse tables used by print heads 130a and 130b are not selected 
at this point, but rather suitable tables are defined for later selection. Preferably, the define heat pulse table command 
50 [DEF1NE_PUL8E] described above in section 3.6 is used. 

[0463] Flow then proceeds to steps 84511 through 84530 which (with the exception of steps 84520 and S4521) 
determine the resolution of a current print band, set print control conditions such as ink ejection drop size and buffer 
readout order, send print data, and command printout of the transmitted print data. 

[0464] In more detail, step 84511 determines whether printout for a particular band or a portion of a t>and is a high 
55 resolution printout or a low resolution printout. If the band or portion of the band is a low resolution printout, flow 
advances to step 84512 which sets appropriate ink ejection droplet sizes for each of heads 130a and 130b. Using the 
example from Figure 45, the droplet size for head 130b is set to large and the droplet size for head 130a is set to small. 
Preferably, the droplet size command [DROP] defined above in section 3.6 is used. 
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[0465] In Step 8451 4, printer driver 114 selects high print speed, corresponding to low resolution printout. Preferably, 
the select speed command [SPEED] defined above in section 3.6 is used. 

[0466] Step S4516 selects offsets for readout order of print buffer 139 in accordance with the selected low resolution. 
Specifically, step S4516 selects one of the buffer control tables set above in step S4509. Preferably, the select buffer 
control table command [SELECT_CONTROL] defined above in section 3.6 is used. 

[0467] Step S451 7 transmits image data, block-by-block as discussed in section 3.6 from printer driver 1 1 4 to printer 
30 over a bi-directional interface. Once an entire band of print data has been transmitted to printer 30, printer driver 114 
initiates printout of the band in step 84519 by transmission of the print execution command [PRINT]. Step 84520 then 
determines whether further bands need to be printed in accordance with which flow either returns to step 8451 1 or flow 
terminates at step S4521 . 

[0468] Reverting to step 8451 1. if a high resolution band of print information is to be transmitted arxJ printed, then 
steps S4522 through S4530 execute in the printer driver 1 14 so as to perform complementary steps to the low resolu- 
tion steps of 84512 through 84519. Thus, step S4522 sets small drop sizes, step 84525 sets a low print speed corre- 
sponding to high resolution, step 84526 selects a high resolution nozzle firing sequence, step 84527 selects readout 
order from print buffer 139 by selecting one of the pre-defined buffer corrtrol offset tables, step 84529 transmits high 
resolution image data band by band to printer 30. and step 84530 initiates printout of a fully-transmitted band. 
[0469] According to a second embodiment, a print head prints pixels of a horizontal print band in the scan direction 
of printer 30 in differing resolutions without requiring reverse sheet feed, thereby increasing overall printing efficiency. 
[0470] Although this embodiment is described below with reference to a printer having multiple print heads, it will be 
noted that the below-described embodiment also provides significant benefits when used in conjunction with single print 
head printing. 

[0471] As described above, the resolution with which a print head prints may be determined manually by user input, 
or automatically based, for example, on content of print data; type of recording medium, or, in the case of a multiple print 
head system, a relative head configuration of print heads 130a and 130b. 

[0472] Advantageously, printer 30 therefore receives commands to set resolution for each of print heads 130a and 
1 30b independently, and effects printout at the set resolutions. : - 

[0473] Figure 46A is a representational view for explaining the benefits of controlling a print head to print out at mul- 
tiple resolutions. In Figure 46A. 420 indicates a printed sheet on recording medium 421 having various types of - print 
information. Area 420a, 420b , 420c, and 420d are text areas consisting primarily of black and white areas. Accordingly, 
information contained in these text areas is satisfactorily printed in a low resolution. In contrast, area 424 is a non-text 
area, such as a color image or graphic or line drawing, for which a high resolution is preferred. It should be noted that' 
areas 420b and 424 are located on a common horizontal print band in the scan direction of printer 30. 
[0474] 425 is an enlarged view of a portion of area 420b. Enlarged view 425 depicts print heads 1 30a and 1 30b. Each 
of print heads 130a and 130b include yellow, magenta, cyan and black print nozzles arranged vertically, with 24 nozzles 
for yellow. 24 nozzles for magenta, 24 nozzles for cyan and 64 nozzles for tHack. Of course, other configurations for 
heads 130a and 130b are possik^e. 

[0475] Because area 420b is a text area for which low resolution is adequate, printing of area 420b is performed in a 
low resolution/high speed mode, as shown at 425. In area 425. one low resolution t>and 426 is printed by print heads 
1 30a and 1 30b and depicted in cross-hatched emphasis. To print at this resolution, printer 30 is commanded to put print 
heads 130a and 130b into a large droplet ejection mode, and print data read out from print buffer 139 is selected in 
accordance with the selected resolution. These steps are described more fully below in connection with the flowchart 
ofRgure46B. 

[0476] in contrast to area 420b, area 424 is an area for which high resolution print out is desired. This situation is 
depicted in the enlarged area at 427 which shows printout by print heads 1 30a and 1 30b only at band 429. As described 
more fully below in connection with the flow chart of Figure 468, to effect printout in the band shown at 429, print heads 
130a and 130b are commanded to eject ink in small droplets, and the data read out from print buffer 139 is selected in 
accordance with the selected resolution. 

[0477] To print areas such as 420b and 424 which are mixed in a lateral direction in the direction of a scan of print 
heads 130a and 130b across recording medium 421 . a two-step procedure is employed. In one step, sequential barxis 
such as band 429 are printed by print heads 130a and 130b. The number of sequential t^ands such as 429 which are 
printed corresponds to the ratio between the number of print nozzles for each of cyan, magenta and yellow inks, in this 
case 24, and the numk)er of nozzles used for black color, in this case 64. In the second step, a single pass from print 
heads 130a and 130b is effected, thereby printing a band of area 420b. During the second pass, ink is ejected in a low 
resolution from the black nozzles of print heads 130a and 130b. By virtue of this two step process, recording medium 
420 can be advanced in a single direction, without requiring reverse feed, so as to effect a varied-resolution printout of 
area 402b and 424. 

[0478] Rgure 46B Is a flow diagram showing process steps executed by printer driver 1 14 in host processor 23 so as 
to control print resolution for each print head, and to command printout to be effectuated thereby. Generally speaking. 
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the process steps shown in Figure 46B are stored program instruction sequences that set print resolution by controlling 
ink droplet size for each head, and by controlling readout order from print buffer 139 for each print head. 
[0479] More specifically, in step S4601 , a user of host processor 23 issues a command from an application to print 
print data, thereby actuating printer driver 114. Printer driver 114 actually performs many more functions than indicated 

5 in the remainder of Figure 46, but only those functions having some bearing on setting of print resolution are described. 
Thus, in step S4602, printer driver 114 deternriines whether print resolution should be designated automatically by 
printer driver 114, or whether the print resolution should be designated manually by the user. In step S4602, a user 
interface is displayed to the user, such as the representative user interfece shown in Figure 46. As seen there, section 
410, when selected by the user, provides for automatic designation of print resolution. On the other hand, when 41 1 is 

10 selected, the user manually designates print resolution. Separate resolutions may be specified for non-text graphics as 
well as for text, with the user being able to designate manually either high speed (i.e., low resolution) or high quality (i.e., 
high resolution) for each of text and non-text regions. 

[0480] Reverting to Figure 46B, if automatic designation has been selected, then flow branches to step S4604 in 
which printer driver 114 automatically selects resolution for graphics, and then to step S4605 in which printer driver 114 

15 automatically selects resolution for text. Selection of resolution for graphics and for text is based on continuous-tone 
print data, and is made in accordance with the presence of graphics and other non-text information, the presence of text 
information, the type of recording media selected for printout, arxi. In tiie case of a multiple printed system such as that 
described herein, the relative print head configurations of print head 130a and print head 130b. 
[0481] Flow next advances to step S4606 In which printer driver 1 14 determines whether dual resolutions have been 

20 specified, either manually or automatically. If ho dual resolutions have been specified, then flow branches to step 84607 
to proceed with printing in a uniform resolution for both heads. On the other hand, if dual resolutions have been speci- 
fied, then flow advances to step 84609 so as to control print resolution of each print head and to effect printout thereby. 
[0482] Thus, step 84609 defines buffer control tables, one of which is selectable for each head and by which each 
print head can determine readout order for readout of print data from its respective print buffer. Actual selection of which 

25 buffer control table to use is not effectuated until later in the procedure, but step 84609 merely defines suitable buffer 
. control tables for each resolution and for each direction of printout. Preferably, the define buffer control table command 
[DEFINE_CONTROL]'described above in section 3.6 is used. 

[0483] Likewise, step 84610 defines suitable heat pulse tables by which the firing sequence for each nozzle in print 
heads 130a and 130b is controlled. The actual heat pulse tables used by print heads 130a and 130b are not selected 
30 at this point, but rather suitable tables are defined for later selection. Preferably, the define heat pulse table command 
[DEFINE1.PUL8E] described above in section .3.6 is; used. 

[0484] Flow then proceeds to steps 8461 1 through 84630 which (with tiie exception of steps 84620 and 84621) the 
resolution of a current print band Is determined, print control conditions such as ink ejection drop size and buffer readout 
order are set. print data is sent, and printout of the transmitted print data is commanded. 

35 [0485] In more detail, step 8461 1 determines whether printout for a particular band or a portion of a barxj is a high 
resolution printout or a low resolution printout. If the band or portion of the band is a low resolution printout, flow . : 
advances to step 84612 which sets appropriate.ink ejection droplet sizes for each of heads 130a and 130b. Using the 
example from Figure 44, the droplet size for heads. 1 30a and 1 30b is set to large; Preferably, the droplet size command 
[DROP] defined above in section 3.6 is used. 

40 [0486] In Step 84614, printer driver 114 selects the high print speed, corresponding to low resolution printout Pref- 
erably, the select speed command [SPEED] defined above in section 3.6 is used. 

[0487] Step 84616 seleicts offsets for readout order of print buffer 139 in accordance with the selected low resolution. 
Specifically, step 84616 selects one of the buffer control tables set above in step S4609. Preferably, the select buffer 
control table comnnand [SELECT_CONTROL] defined above in section 3.6 is used. 
45 [0488] Step 8461 7 transmits Image data, block-by-block as discussed in section 3.6, from printer driver 1 14 to printer 
30 over a bi-directional interface. Once an entire band of print data has been transmitted to printer 30, printer driver 114 
initiates printout of the band in step 84619 by transnaisslon of the print ^ecution command [PRINT]. Step S4620 then 
determines whether further bands need to be printed in accordance witii which flow either returns to step 8461 1 or flow 
terminates at step S4621. 

50 [0489] Reverting to step 8461 1 , if a high resolution band of print information is to be transmitted and printed, then 
steps 84622 through 84630 execute in tiie printer driver 1 14 so as to perform complementary steps to the low resolu- 
tion steps of 84612 through 84619. Thus, step 84622 sets small drop sizes, step 84624 sets appropriately large buffer 
sizes, step 84625 sets a low print speed corresponding to high resolution, step 84626 selects a high resolution nozzle 
firing sequence, step 84627 selects readout order fronri print buffer 139 by selecting one of the pre-defined buffer con- 

55 troi offset tables, step 84629 transmits high resolution image data band by band to printer 30, and step S4630 initiates 
printout of a fully-transmitted band. 

[0490] From tiie perspective of printer 30, Figure 47 is a flow diagram illustrating the process steps performed by 
printer 30 for independent print resolution setting. Thus, in step 84701 , printer 30 receives control commands so as to 
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prepare printer 30 for high or low print resolution for each print head. As discussed above, these control commands 
include commands to set the speed of printing, the size of the ejected nozzle, the nozzle firing sequence, and the print 
buffer readout order. - 

[0491 ] In step S4702, print data is received from printer driver 1 1 4, followed in step S4703 by a print command. There- 
5 after, in step S4704, depending on whether a high or a low print resolution has been commanded, the print data 
received in step S4702 is printed as commanded in step S4701 . Thus, as shown in step S4705. for a high print resolu- 
tion, print data is printed at a low speed, with small droplet size, with a high resolution nozzle pulse sequence table, and 
with a high resolution buffer control readout order. Likewise, at step S4706. for a low resolution printout, printout is 
effected at a high speed, with a large droplet size, with a fow resolution nozzle pulse sequence table, and with a low 
10 resolution buffer offset readout sequence. In either event, flow proceeds to step S4707 to await the next print command 
sequence. 

• [0492] As described with respect to Figures 46A and 46B. a single print head.may be controlled to print print data on 
a single print band in a scanning direction using both sets of printing characteristics set forth in step S4705 and step 

.S4706. ■ 

15 ■ ■ - 

11.0 Selection Off Alternative Inks 

[0493] As described above, printer 30 can be configured to output several types of ink onto a single recording media. 
Advantageously, this feature allows printer 30 to print an image using both dye-based black ink and pigment-based 
20 black ink. 

[0494] In a preferred embodiment, dye-based black ink is used in conjunction with differently-colored inks to facilitate 
color printing. As a result, when used to print black pixels within a color image, dye-based black ink allows the color 
image to maintain a substantially uniform optical density. 

[0495] In contrast, pigment-based black ink, when used to print black pixels within a color image, contrasts sharply 

25 with other regions of the color image, thereby disturbing uniformity of the color image. However, many cases exist In 
which it is desirable to maintain significant contrast between a black printed region arxi a differently-colored region. 
Most notable among these cases is the printing of black text upon a white recording medium. Therefore, pigment-based 
black ink is preferably used to print text data. « ■ ' 

[0496] Therefore, in the above-described embodiment, selection of dye-based black ink or pigmentrbased black ink 

30 to print a black target pixel is based upon content of image data surrounding the black target pixel. More specif ically, in 
a case that a black ^rget pixel is judged to correspond to a differently-colored region of image data, the target pixel is 
printed using a dye-based black ink. If not. the. target pixel is printed using a pigment-based black ink. One methdd'of 
judging whether a black pixel corresponds to a differently-colored region of image data is desaibed below with r^pect 
to Figure 49. Preferably, such judging is performed based on multi-level image data so that accurate characterization of 

35 image conterrt can be achieved. . 

[0497] ' Since the above-described visual properties of various inks depend upon degrees of ink penetration into a 
recording medium, recording media type plays a significant role in determining whether dye-based, or other high-pen- 
etration black inks, or low^-penetration black inks such as pigrhent-t>ased inks are more appropriate for a particular print 

' . "job. ■ ' ■■: •. • ■ :.. ■ ■ ■ - - . 

4o: [0498] Plain paper, for example, has been shown to exhibit poor ink absorption qualities and therefore is not desirable 
for use with high-penetration black inks because the inks do not effectively combine within the recording media so as to 
produce consistently-reprodudble colors. On the other hand, spedally-coated paper is available which provides for a 
more uniform combination of variously-colored high-penetration inks deposited thereon. Unfortunately, such specially- 
coated paper is unsuitable for use with low-penetration inks. 

45 [0499] In view of the foregoing, a type of ink used to prim pixels on a recording medium preferat>ly depends on both 
the type of image corrtaining the pixel data and the recording medium upon which the ink is to be placed. 
[0500] Figure 48 is a flow diagram for describing a method of ink selection based on recording medium type and 
image coritenti Generally, in order to control an ink jet printer to print pixels corresponding to multi-level image data 
upon a recording medium using either a first ink or a secorxi inK it is determined whether the recording medium is plain 

50 paper or spedally-coated paper, and. in a case that the recording media is determine to be specially-coated paper, the 
printer is commanded to print a target pixel using the first ink. On the other hand, in a case that the recording media is . 
• determined to be plain paper, it is determined whether or not the target pixel corresponds to a differently-colored region. 
' In a case that the target pixel corresponds to a differently-colored region, the printer is instructed to print the target pixel 
using the first ink. Conversely, in a case that the target pixel does not correspond to a differently-colored region, the 

55 printer is instructed to print the target pixel using the second ink 

[0501] In more detail, flow begins at step S4801, wherein a paper type is determined. As shown In the Figure, the 
preferred embodiment contemplates the use of either plain paper or spedally-coated paper. Preferably, the specially- 
coated paper is *1iigh resolution" paper HR-1 01 . as described in section 1 .0. 
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[0502] In a case that the paper type is determined to be specially-coated paper, flow proceeds to step S4802, wherein 
it is determined that a high-penetration ink should be used for printing black pixel data. This determination is based on 
an assumption that high-penetration black ink Is always more suitable for printing black pixel data upon a specially- 
coated recording medium, regardless of Image type. 
5 [0503] If. in step S4801 , the paper type is determined to be plain, flow proceeds to step S4803, in which it is deter-, 
mined whether a black target pixel exists within a color region of the Image to be printed. If so. flow proceeds to step 
S4802, as described above. If not, flow proceeds to step S4804. wherein It Is determined to print the target pixel using 
low-penetration black ink. 

[0504] According to a preferred embodiment, the determination of step S4803 is made by examining image pixels 
10 surrounding the target pixel. Figure 49 is a diagram for describing this particular embodiment. 

[0505] Figure 49 shows black target pixel 415 within 5x5 grid of image data 416. Each subdivision of grid 416 rep- 
resents a single image pixel. Preferably, each Image pixel Is represented by three 8-blt values, each 8-blt value repre- 
senting red, green, and blue components of the image pixel. In order to determine whether black target pixel 415 is 
located within a differently-colored region, the red, green, and blue components of each pixel in grid 416 are compared 
IS using the following equations: 

:r - b: < a: :b - G: < p; and IG - Rl < y. 

wherein a, p, and y are relatively small values. 

20 [0506] If each equation Is satisfied for each pixel within grid 41 6. black target pixel 41 5 is determined not to exist within 
a differently-colored region. Alternatively, step S4803 may require that the red. green, and blue components of each 
pixel in grid 41 6 satisfy the equation R = G = B in order to determine that the target pixel does not exist within a differ- 
ently-colored region. However, this alternative method Is susceptible to errors in image data caused by noise, poor 
scanning, or the like. Accordingly, a. p. and y are used as shown above to provide a small tolerance for data en-ors. Of 

25 course, other methods may be used In step S4803 for determining whether black target pixel 41 5 Is within a differently- 
colored region. 

[0507] Advantageously, multi-level data Is used to determine differently-colored regions in the above-described 
embodiment. In contrast, a system utilizing iDinarized data to determine differently-colored regions may mistakenly inter- 
pret a 50% gray region of original image data to consist of alternate regions of black and white pixels. As a result, inap- 
30 propriate inks might be used to print the "black" regions, 

. [0508] It should be understood that, although the above description of selection of alternative inks specifically focuses 
on highrpenetration black ink arxJ low-penetration black Ink. |t Is contemplated to utilize the foregoing in conjunction with 
any first ink and second ink differing from one another |n color, penetration characteristic, or other characteristic, such 
as viscosity or density. 

35 [0509] Furthermore, although plain and specially-coated high- resolution papers are discussed above, a determination 
of appropriate ink may be based upon any media type. Additional contemplated media include transparencies, . glossy - 
paper, glossy film, back print film, fabric sheets, T-shirt transfers. Bubble Jet paper, greeting card stock, and brochure 
paper, among others. In this regard, paper type can be detected by a paper sensor located within printer 30, or Input 
through a user interface displayed on display screen 22, or input via a button located on printer 30. 

40 [0510] It should also be noted that, in the preferred embodiment, printer driver 114 contains computer-executable 
steps to execute the flow of Figure 48. Of course, these steps could be wholly contained within ROM 122 of printer 30 
or coutel be stored jointly within computer-readable, memories of host computer 23 and printer 30. 

11.1 Selection of CMYK Black or Pigment Black 

45 

[051 1] It has been noted that PCBk may be utilized to print black pixels upon a recording medium. Alternatively, pig- 
ment-based black Inks and dye-based black inks have also been used to print such pixels. Printer 30 provides additional 
functionality by providing selectable printing of black pixels using either pigment-based black ink or a combination of 
cyan, magenta, yellow, and black dye-based inks. 

so [0512] In order to do so. It is initially determined whether a black target pixel corresponds to a differently-colored 
region. In a case that it Is determined that the black target pixel does not correspond to a differently-colored region, a 
printer Is Instructed to print the black target pixel using a pigment-based black ink. Otherwise, the printer is instructed 
to print the black target pixel using a dye-based black ink and dye-based ink of each of subtractive primary colors. 
[0513] Figure 49A is a flow diagram for specifically descrik>ing the foregoing features. In step S4901. it is determined 

ss whether a black target pixel corresponds to a color region. Preferably, this determination is based upon multi-level data 
representing a region adjacent to the black target pixel. Such a method Is described In detail above with respect to Fig- 
ure 49, and is therefore omitted at this point. 

[051 4] In a case that the target pixel is determined to exist witNn a color region, flow proceeds to step S4902, In which 
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the target pixel is printed using a combination of dye-based black ink and dye-based cyan, magenta, and yellow inks. 
Upon reaching step S4904. the target pixel has been determined not to exist within a color region. As a result, the target 
pixel Is printed using a pigment-based black ink. 

[051 5] Notably, the foregoing features allow black pixels within color areas of an image to exhibit a truer black color 
5 than that achieved using PCBk. while utilizing blending of various dye-based inks in order to maintain a relatively uni- 
form output density within the color area. In addition, the foregoing selectability allows isolated black pixels to be printed 
using pigment-based black ink. thereby allowing more accurate reproduction of such black image data. 
[051 6] As stated with respect to previous embodiments, printer driver 114 contains conputer-executable steps to exe- 
cute the flow of Rgure 49A. Of course, these steps could be wholly contained within ROM 122 of printer 30 or could be 
10 stored jointly within computer-readable memories of host conrputer 23 and printer 30. 

11.2 Boundary Region Printing 

[0517] As mentioned above, conventionally-printed black/color boundary regions suffer from several deficiencies. 
15 First, such regions are often identified based on binarized data of an original multi-level image. However, binarized 
image data often does not accurately approximate actual multi-level image data. As a result, a boundary region may be 
"identified'* at a position where no such region exists within the original image. 

[051 8] Second, low-penetration black Inks used to print a black region tend to bleed into adjacent color regions printed 
using high-penetration ink. PCBk has been proposed as a buffer between such a color region and a region of low-pen- 

20 etration black ink. However, as shown in Figure 50A. such a buffer is unsatisfactory because the different optical densi- 
ties of PCBk region 422 and low-penetration black ink. region 424 cause an abrupt visual discontinuity. 
[0519] It has also been proposed to print black/color boundary regions using high-penetration black ink and a PCBk 
"buffer**; As shown in Rgure SOB, although optical densities of PCBk region 426 and high-penetration black ink region 
427 are more similar than shown in Figure 50A, the black color produced by high-penetration black ink is unsuitable for 

25 producing -high-quality solid black regions. 

[0520] Figure 51 is a flow diagram describing a method for printing a boundary region. Generally, the method includes 
detecting a boundary between a black region of an image and a differently-colored region of the image^ instructihg a 
printer to print a first region of black pixels within the black region and adjacent to the tx)undary using process black, 
instructing the printer to print a second region of black pixels within the black region and adjacent to the first region using 

30 high-penetration black ink, and instructing the printer to print a third region of black pixels within the l)lack region and 
adjacent to the second region using low-penetration black ink. .. . v 

[0521] In particular, flow begins at step S5101 . in which a boundary between a black region of an image and a differ- 
ently-colored region of the image is detected. With reference to Figure 50C. step S5101 results in detection of boundary 
429 between differently-colored region 430 and black region 432. As desicribed above, boundary detection is preferably 

35 based on multi-level image data so as to detect black/differentiy-colored bourxJaries more accurately than systems 
which perform boundary detection using binarized image data. 

[0522] Row proceeds to step 851 02. in which a printer is instructed to print a first region of black pixels using PCBk. 
As shown in Figure 50C. first region 431 is within black region 432 and adjacent to iDoundary 429. 
[0523] Next, in step 85103, the printer is instructed to print a second region of black pixels using a high-penetration 
40 t^tack ink. The second region is depicted in Figure 50C as region 434. Advantageously, second region 434 is adjacent 
to first region 431 and within black region 432. 

[0524] lastly, the printer is instructed, in step 85104. to print a third region of black pixels using a low-penetration 
black ink. As shown in Rgure 50C, third region 436 is adjacent to second region 434 and within black region 432. 
[0525] It should be understood that sizes of the first, second, and third regions may be adjusted based on a number 
45 of PCBk pixels desired and on a number of high-penetration black ink pixels desired in a t>oundary region between a 
black region and a differently-colored region. 

[0526] As a result of the Figure 51 flow, optical density changes gradually across a boundary between a black region 
and a differently-colored region, bleeding between the black region and the color region is reduced, and a high-quality 
k>tack region is obtained. 

50 [0527] Printer driver 114 may contain computer-executable steps to execute the flow of Figure 51 . These steps may 
also be contained within ROM 122 of printer 30 or may be stored jointly within computer-readable memories of host 
processor 23 and printer 30. 

[0528] Figure 52 illustrates a more detailed method for printing a boundary region between a black region and a dif- 
ferently-colored region. 

55 [0529] In general, Figure 52 describes a system to control printing of pixels corresponding to image data using an ink 
jet printer which includes a reservoir of a high>penetration black ink. a reservoir of ink of a low-penetration black inK and 
a reservoir of ink to create process black. According to the system, it is determined, based on the image data, whether 
or not a first region of a first predetermined size adjacent to a black target pixel includes a differently-colored region. In 
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a case that it is determined that the first region includes a differently-colored region, the printer is instructed to print the 
target pixel using process black. In a case that it is determined that the first region does not include a differently-colored 
region, it is determined, based on the image data, whether or not a second region of a second predetermined size adja- 
cent to the target pixel includes a differently-colored region, the secorxJ region being larger than the first region. Finally. 
5 in a case that it is determined that the second region includes a differently-colored region the printer is instructed to print 
the target pixel using the high-penetration black ink, otherwise the printer is instructed to print the target pixel using the 
low-penetration black ink. 

[0530] More specifically, flow begins at step S5201 . in which a black target pixel is identified within original image data. 
. Flow proceeds to step 35202. in which it is determined whether a first region adjacent to the target pixel includes a dif- 
10 ferently-colored region. If so. flow proceeds to step S5204. wherein printer 30 is instructed to print the target pixel using 
PCBk. If not. flow proceeds to step S5205. 

[0531] It is determined, in step S5205. whether a second region adjacent to the target pixel identified in step S5201 
includes a differently-colored region. Notably, the second region is larger than the first region analyzed in step S5202. 
Accordingly, step S5205 confirms whether the target pixel is located near to a differently-colored region. If so. flow pro- 

15 ceeds to step S5206, in which printer 30 is instructed to print the target pixel using high-penetration black ink. If not. flow 
continues to step S5208. at which printer 30 is instructed to print the target pixel using low-penetration black ink. 
[0532] Rgure 53A illustrates detection of a first differently-colored region according to a preferred enr^xxfiment of step 
S5202. Figure 53A shows a region of differently-colored multi-level image data 450 and a region of black multi-level 
image data 451. For the foregoing explanation, the target pixel identified in step S5201 is represented by pixel data 

20 location 452. In addition, 5 x 5 region 454 is the first region analyzed in step S5202. 

[0533] In order to determine whether region 454 includes a differently-colored region, the algorithm described above 
with respect to Rgure 49 is applied to the pixel values within region 454. Preferably, multi-level pixel values are used in 
order to accurately detect black pixels and differently-colored pixels within region 454. Since region 454 contains color 
values from region 450, printer 30 is instructed, in step S5204. to print target pixel 4524 using PCBk. 

25 [0534] This instruction is reflected in Figure 53C, which is a representation of printed pixels corresponding to the 
image data of Figure 53A, As shown in Figure 53C. printed pixel 456, representing pixel location 452, is printed using 
PCBk. In this regard; it should be understood that printed jDixel 457, representing pixel location 459, is also printed using 
PCBk. s 

[0535] Steps S5205 to S5208 are described in more detail below with respect to Figures 53B and 53C. In particular, 
30 second region 460, adjacent to pixel data location 461 and larger than first region 454, is analyzed to determine whether 
it includes a differently^colored region. Accordingly, printer 30 is instructed to print pixel 462, which corresponds to pixel 
data location 461, using high-penetration black irik. 

[0536] As can be seen from Figure 53B. second regiori 464 adjacent to pixel data location 466 does not contain a 
differently-colored region. Therefore, in accordance with step S5208, printer 30 is instructed to prirrt pixel 467, which 
35 corresponds to pixel data location 466. using low-penetration black ink. 

■ [0537] As a result of the Figure 52 flow, a boundary region such as that shown in Figure 50C is obtained. -Specif ically^ . 
optical density changes gradually across the boundary region, bleeding between the black region and the differently- 
colored region is reduced, and the black region is printed using tow-penetration black ink. 

[0538] Of course, sizes of the first region and of the second region may be adjusted based on a number of PCBk pix- 
40 els desired and on a number of high-penetration black ink pixels desired in a bourxJary region between a . black region 
and a differently-colored region. 

[0539] As discussed with respect to the previous embodiments, printer driver 114 may contain computer-executable 
steps to execute the flow of Figure 52. These steps may also be contained within ROM 122 of printer 30 or may be 
stored jointly within computer-readable memories of host processor 23 and printer 30. 

45 

1 1 .3 Printing With Different Inks at Different Resolutions 

[0540] Figure 54 is a flow diagram which depicts processing according to another emtx)diment. As shown in Figure 
54. upon input of pixel data such as 5 x 5 pixel region 416. it is determined, in steps S5402 to S5407, whether a target 
50 pixel in the input pixel data is within a color region. This process is the same as that described above with respect to 
Figure 49. Accordingly, a detailed description thereof is omitted here for the sake of brevity. 

[0541] Steps S5409 to S5412 set forth color correction. i.e., black correction. Specifically, in step S5409, color correc- 
tion is performed on the target pixel so as to chiange the pixel from RGB data into CMYK data. Next, step S5410 deter- 
mines if the target pixel is within a color region. If the pixel is not within a color region, processing proceeds to step 
55 S541 1. In a case that the target pixel is not within a color region, pigment ink (i.e., K1 ink) is set to form the pixel. In 
contrast in a case that step S5410 determines that th pixel is in a color region, black is formed from process black, 
i.e., cyan, magenta, and yellow ink and dye-based (i e., K2) black ink. 

[0542] Next, step S541 3 performs output color correction on the pixel data. For example, gamma correction or the like 
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can be performed in this step. Thereafter, processing proceeds to steps S5414 to S5419. These steps set forth binari- 
zation. 

[0543] More specif ically, step S5414 determines whether the target pixel is within a color region. In a case that the 
target pixel is within a color region, processing proceeds to step S5418. in which the target pixel is binarized with a 2 x 
5 2 Index, and to step S5419 in which the pixel is printed in 720 x 720 resolution with dye-based black pigment ink (see 
Figure 54A). On the other hand, in a case that step S5414 determines that the target pixel is not within a color region, 
processing proceeds to step S5415, in which the pixel is binarized with a 1 x 1 index, and to steps S5417 In which the 
pixel is printed in 360 x 360 dpi with pigment-based black ink (see Figure 54B). Thereafter, processing ends. 

10 Claims 



1. A method for controlling a print head of an image printing device having at least one print head, comprising the 
steps of: 

15 obtaining profile information of the at least one print head; 

storing the profile information in a non-volatile memory; 

outputting. upon request the profile Information to a host computer connected to the image printing device, 
wherein the host computer utilizes the profile information to produce compensation parameters which compen- 
sate print information to be sent from the host conrputer to the print head for printing. 

20 

2. A method according to Claim 1 . wherein, in said obtaining step, the image printing device receives a command from 
the host computer to print a test pattern, said image printing device prints the test pattern, the host computer sends 
a command to the image printing device to scan and obtain measurements relating to the test pattern, and the 
image printing device performs the scan and obtains the requested measurement information and transmits tiie 

25 measurement Information to the host computer. 

3. A method according to Claim 1 . wherein, in the obtaining step, tiie profile parameters relate to print head alignment. 
image optical density, a last cleaning of a print head, amount of waste ink accumulated, alignment sensor informa- 
tion, a number of times each print head has been replaced, printer ID, and print head ID Information. 

30 

4. A printer driver stored dri a computer readable medium, the printer driving comprising: . 

accessing means for causing a non-volatile memory In a printer to be accessed; 

means for controlling the printer to print a test pattern t>ased on irtfbrmation accessed in the non-volatile mem- 

35 ory; 

means for causing a sensor in the printer to scan a printed test image; 
means for causing measured data resulting from the scanned test pattern to be retrieved; and 
means for causing compensation peu^ameters to be derived based on the retrieved measured data, wherein the 
derived compensation parameters are used to compensate for physical characteristics of the print head. 

40 

5. A printer driver according to Claim 4. wherein the information accessed from the non-volatile memory is utilized by 
a host conrputer to generate appropriate commands foi' printer operation by taking into account the information 
stored in the non-volatile memory. 

45 6. A printer driver according to Claim 5. wherein the accessed information from the non-volatile memory of the printer 
indicates whether a new print head has been installed. 

7. A printer driver according to Claim 5. furtiier comprising means for controlling the printer to perform various printer 
tasks, wherein in the case the information accessed from the non-volatile memory in the printer indrcates that a new 
50 print head has been installed, controlling the printer to produce a test pattern, to scan the test pattern and to store 
measurements of the test pattern produced by the scan. 



8. A method for compensating for physical characteristic variations in an Inkjet print head used in a printer, the method 
comprising the steps of: 

55 

causing a non-volatile memory in a printer to be accessed; 

controlling a printer to print a test pattern based on information accessed in a non-volatile memory; 
causing a sensor attached to a print head in the printer to scan a printed test image; 
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causing measured data resulting from the scanned test pattern to be retrieved; and 

causing compensation parameters to be derived based on the retrieved measured data, wherein the derived 
compensation paramiaters are used to compensate for physical characteristics of the print head. 

5 9. A method according to Claim 8. wherein the information accessed from the non-volatile memory is utilized by a host 
computer to generate appropriate commands for printer operation by taking into account tiie information stored in 
the non-volatile memory. 

10. A metiiod according to Claim 8, wherein the accessed information from the non-volatile memory of the printer irxii- 
10 cates whether a new print head has been installed. 

1 1 . A method according to Claim 8, further comprising the step of causing the printer to perform various printer tasks, 
wherein in the case tiie information accessed from the non-volatile memory in the printer indicates that a new print 
head has been installed* controlling the printer to produce a test pattern, to scan the test pattern and to store meas- 

15 urements of the test pattern produced by the scan. 

1 2. A printer controller for a printer having at least one print device comprising: 
receiving means for receiving image information from an external device; 

controlling means for corrtrolling a printer to form an image based on the image information received by said 
receiving means; and - 

storing means for storing information concerning the printer; 

wherein a part of the storing means is non-volatilie and stores the information which is used by the external 
device for producing the image information. . 

A printer controller according to Claim 12, wherein said part of the storing means stores information representing 
a condition of the printer. • . . . 

1 4- A printer controller according to Claim 1 2, wherein said part of the storing means stores a profile parameter relating 
30 to at least one of print head alignment, image optical density, a last cleaning of a print head, amount of waste ink 
accumulated, alignment sensor information, a number of times each print head has been replaced, printer ID, and 
print head ID information.' 

15. A printer controller according to Claim 12, wherein said profile parameter is sent to tiie external device in response 
35 to request of the external device. 

1 6^ A printer controller according to Claim 12, wherein said storing means comprises an EEPROM. 

1 7. A printer driver for a printer having at least one print device comprising: 

40 

sending means.for sending commands to tiie printer for accessing a non-volatile memory in the printer; 
obtaining means for obtaining profile information corx;erning the prirrter stored in the non-volatile memory; and 
producing means for producing image information for printing an image by the printer based on the profile infor- 
mation. 

45 

18. A printer driver according to Qaim 1 7, wherein said profile information represents a condition of the printer. 

19. A printer driver according to Claim 17. wherein said profile information relates to at least one of print head align- 
ment, image optical density, a last cleaning of a print head, amount of waste ink accumulated, alignment sensor 

50 information, a number of times each print head has been replaced, printer ID, and print head ID information. 

20. A printer driver according to Claim 17. wherein said non-volatile memory comprises an EEPROM. 

21. Computer executable program codes stored in a computer readable medium for forming an image using a printer 
55 having at least one print device conprising: 

a first set of computer executable program codes for sending commands to the printer for accessing a non-vol- 
atile memory in the printer; 
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a second set of computer executable program codes for obtaining profile information concerning the printer 
stored in the non-volatile memory; and 

a third set of computer executable program codes for producing image information for printing an image by the 
printer based on the profile information. 

5 

22. Computer executable program codes stored in a computer readable mediurh according to Claim 2^, wherein said 
profile information represents a condition of the printer. 

23. Computer executable program codes stored in a computer readable medium according to Claim 21, wherein said 
10 profile information relates to at least one od print head alignment, image optical density, a last cleaning of a print 

head, amount of waste ink accumulated, alignment sensor information, a number of times each print head has 
been replaced, printer ID, and prirrt head ID information. 

24. Computer executable program codes stored in a computer readable medium according to Claim 21 , wherein said 
15 non-volatile memory comprises an EEPROM. 

25. A printer controller for a printer having at least one print device comprising: 

receiving means for receiving image information from an external device: 
20 controlling means for controlling a printer based on the image information; and 

non-volatile memory means for storing information concerning a condition change of the printer which may 
occur during an off-line mode; and 

trsinsmitting means for transmitting the information to the external apparaltus during a next on-line mode. 

25 26. A printer controller according to Claim 25. wherein said information relates to whether said print device has been 
changed or not. ' 

27. A printer controller according to Claim 26, wherein said external device instructs the printer to dean a print head of 
the changed head in accordance with the information. 

30 

28. A pi-inter controller according to Claim 25, wherein said non-volatile memory means comprises an EEPROM. 

29. A printing system/ comprising: 

an external host computer having at least a host processor, a memory, a bi-directional printer-interface and a 
printer driver, said external host computer performing at least processing, storing and outputting of print data, 
print commands arxJ printer parameters; and 

a printer having at least a bi-directional port, a non-volatile memory, a volatile memory, a print engine, an align- 
ment sensor, at least one print head and a processor, 

wherein the host computer sends a request command through the bi-directional interface to the printer for pro- 
file information of the at least one print head and wherein the printer stores profile information in the non-vola- 
tile memory arxi in response to a request for the profile Information outputs the profile information to the host 
processor through its bi-directional port. 

45 30. A printing system according to Claim 29. wherein the host computer utilizes profile information to produce compen- 
sation parameters which compensate print commands sent to the printer and wherein the print engine controls the 
at least one print head to print data based on the conrpensated print commands. 

31. A printing system according to Claim 29, wherein the host computer commands the printer to print a test pattern, 
50 to scan the printed test pattern with the alignment sensor, to store scanned information in the volatile memory, and 

to output the stored information from the volatile memory through the bi-directional port and via the bi-directional 
interface to the host computer. 

32. A printing system according to Claim 29, wherein the host computer utilizes the scanned information from the align- 
55 ment sensor to produce compensation parameters for the at least one print head and wherein the host computer 

transmits the produced compensation parameters to the printer and commands the printer to store the produced 
compensation parameters in the non-volatile memory. 
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33. An image printing device having at least one print head and including the printer controller according to any one of 
claims 12 to 16. 

34. A signal carrying the printer driver according to any one of claims 4 to 7 or 17 to 20. 
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FIG. 7B 
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